/* ═══════════════════════════════════════════════════════════
   DESIGN SYSTEM — Pos Ronda
   Theme: Clean dark navy · Accent: indigo/sky blue
   Font: Plus Jakarta Sans
═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
  --navy-950: #050d1a;
  --navy-900: #071224;
  --navy-800: #0c1a34;
  --navy-700: #122244;
  --navy-600: #1a2e58;
  --blue-400: #60a5fa;
  --blue-500: #3b82f6;
  --blue-600: #2563eb;
  --sky:      #38bdf8;
  --sky-dim:  #0ea5e9;
  --slate-400:#94a3b8;
  --white:    #f1f5f9;
  --red:      #f87171;
  --green:    #4ade80;
  --bg:       #050d1a;
  --bg-card:  #0c1a34;
  --bg-input: #122244;
  --border:   rgba(255,255,255,0.07);
  --border-h: rgba(96,165,250,0.35);
  --accent:   #60a5fa;
  --accent2:  #38bdf8;
  --text:     #f1f5f9;
  --muted:    #94a3b8;
  --max-w:    1100px;
  --r:        10px;
  --r-lg:     16px;
  --r-xl:     20px;
  --ease:     0.22s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  font-size:16px;line-height:1.6;
  background:var(--bg);color:var(--text);overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:#050d1a;}
::-webkit-scrollbar-thumb{background:#1a2e58;border-radius:99px;}

/* ── Layout helpers ──────────────────────────────────────── */
.wrap{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 20px;}
.accent{color:var(--accent);}

/* ── Scroll animations ──────────────────────────────────── */
.appear{opacity:0;transform:translateY(22px);transition:opacity .5s ease,transform .5s ease;}
.appear.in{opacity:1;transform:none;}
.appear.d1{transition-delay:.08s;}.appear.d2{transition-delay:.16s;}
.appear.d3{transition-delay:.24s;}.appear.d4{transition-delay:.32s;}
.appear.d5{transition-delay:.40s;}.appear.d6{transition-delay:.48s;}

/* ═══ NAV ════════════════════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:60px;display:flex;align-items:center;padding:0 24px;
  justify-content:space-between;
  background:transparent;border-bottom:1px solid transparent;
  transition:background var(--ease),border-color var(--ease);
}
#nav.solid{
  background:rgba(5,13,26,.94);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-color:var(--border);
}
.nav-brand{display:flex;align-items:center;gap:9px;font-weight:700;font-size:.92rem;}
.nav-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
  background:var(--accent);box-shadow:0 0 6px var(--accent);
  animation:pulsedot 2.5s ease infinite;
}
@keyframes pulsedot{0%,100%{box-shadow:0 0 4px var(--accent);}50%{box-shadow:0 0 14px var(--accent);}}
.nav-logo-img{width:26px;height:26px;border-radius:50%;object-fit:cover;display:none;}
.nav-brand-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;}

.nav-links{display:flex;align-items:center;gap:2px;}
.nav-links a{
  padding:6px 13px;font-size:.8rem;font-weight:500;
  color:var(--muted);border-radius:7px;
  transition:color var(--ease),background var(--ease);white-space:nowrap;
}
.nav-links a:hover,.nav-links a.on{color:var(--white);background:rgba(255,255,255,.06);}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;}
.burger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:var(--ease);transform-origin:center;}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

.nav-drawer{
  position:fixed;top:60px;left:0;right:0;z-index:99;
  background:rgba(5,13,26,.97);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  padding:12px 16px 20px;
  display:flex;flex-direction:column;gap:2px;
  transform:translateY(-110%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
}
.nav-drawer.open{transform:translateY(0);}
.nav-drawer a{
  padding:11px 14px;font-size:.88rem;font-weight:500;
  color:var(--muted);border-radius:var(--r);
  transition:color var(--ease),background var(--ease);
}
.nav-drawer a:hover{color:var(--white);background:rgba(255,255,255,.05);}

/* ═══ HERO ═══════════════════════════════════════════════ */
#hero{
  min-height:100svh;display:flex;align-items:center;
  padding:90px 0 70px;position:relative;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(5,13,26,.97) 40%,rgba(7,18,36,.88) 100%);
}
.hero-orb{
  position:absolute;border-radius:50%;
  filter:blur(90px);opacity:.1;pointer-events:none;z-index:0;
}
.orb-a{width:480px;height:480px;background:#2563eb;top:-100px;right:-80px;animation:fl1 14s ease-in-out infinite;}
.orb-b{width:280px;height:280px;background:#0ea5e9;bottom:-60px;left:-40px;animation:fl2 11s ease-in-out infinite;}
@keyframes fl1{0%,100%{transform:translate(0,0)}50%{transform:translate(-28px,28px)}}
@keyframes fl2{0%,100%{transform:translate(0,0)}50%{transform:translate(18px,-18px)}}

.hero-inner{position:relative;z-index:1;max-width:660px;}
.hero-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(96,165,250,.1);border:1px solid rgba(96,165,250,.2);
  border-radius:99px;padding:5px 14px;
  font-size:.72rem;font-weight:600;color:var(--accent);
  letter-spacing:.04em;margin-bottom:22px;
  animation:fadeup .65s ease both;
}
.badge-live{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulsedot 2s ease infinite;}
.hero-title{
  font-size:clamp(2.2rem,5.5vw,4.2rem);font-weight:800;
  line-height:1.1;letter-spacing:-.03em;margin-bottom:16px;
  animation:fadeup .75s .1s ease both;
}
.title-grad{
  display:block;
  background:linear-gradient(90deg,var(--blue-400),var(--sky));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-sub{
  font-size:clamp(.88rem,1.8vw,1rem);color:var(--muted);
  min-height:1.8em;margin-bottom:34px;
  animation:fadeup .85s .2s ease both;
}
.hero-sub .caret{
  display:inline-block;width:2px;height:.95em;
  background:var(--accent);vertical-align:middle;margin-left:2px;
  animation:blink .9s step-start infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-btns{display:flex;gap:11px;flex-wrap:wrap;animation:fadeup .95s .3s ease both;}

.hero-scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  z-index:1;display:flex;flex-direction:column;align-items:center;gap:6px;
  color:var(--muted);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;opacity:.5;
}
.scroll-bar{width:1px;height:36px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scbar 2.2s ease-in-out infinite;}
@keyframes scbar{0%,100%{opacity:.3}50%{opacity:.9}}

/* ═══ BUTTONS ════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:10px 22px;border-radius:var(--r);
  font-family:inherit;font-size:.84rem;font-weight:600;
  border:none;cursor:pointer;
  transition:background var(--ease),box-shadow var(--ease),transform var(--ease);
  white-space:nowrap;
}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--blue-500);color:#fff;}
.btn-primary:hover{background:var(--blue-400);box-shadow:0 4px 20px rgba(59,130,246,.4);}
.btn-ghost{background:rgba(255,255,255,.06);color:var(--white);border:1px solid var(--border);}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.14);}
.btn-outline{background:transparent;color:var(--accent);border:1px solid rgba(96,165,250,.32);}
.btn-outline:hover{background:rgba(96,165,250,.08);border-color:var(--accent);}
.btn-discord{background:#5865f2;color:#fff;}
.btn-discord:hover{background:#4752c4;box-shadow:0 4px 18px rgba(88,101,242,.4);}
.btn-whatsapp{background:#22c55e;color:#fff;}
.btn-whatsapp:hover{background:#16a34a;box-shadow:0 4px 18px rgba(34,197,94,.4);}
.btn-danger{background:rgba(248,113,113,.1);color:var(--red);border:1px solid rgba(248,113,113,.22);}
.btn-danger:hover{background:rgba(248,113,113,.2);}
.btn-sm{padding:7px 16px;font-size:.77rem;}
.btn-xs{padding:5px 11px;font-size:.71rem;}
.btn-full{width:100%;justify-content:center;}

/* ═══ STATS ══════════════════════════════════════════════ */
.stats-strip{background:var(--navy-900);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);}
.stat-cell{padding:30px 20px;text-align:center;border-right:1px solid var(--border);}
.stat-cell:last-child{border-right:none;}
.stat-num{
  font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:800;line-height:1;
  color:var(--accent);margin-bottom:6px;
}
.stat-lbl{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}

/* ═══ SECTION SHELL ══════════════════════════════════════ */
.section{padding:80px 0;}
.section-alt{background:var(--navy-900);}
.sec-eye{font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:9px;}
.sec-title{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;margin-bottom:13px;}
.sec-body{font-size:.93rem;color:var(--muted);line-height:1.78;max-width:540px;}

/* ═══ ABOUT ══════════════════════════════════════════════ */
.about-layout{display:grid;grid-template-columns:270px 1fr;gap:44px;align-items:start;}
.profile-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
}
.profile-banner{
  height:100px;
  background-color:var(--navy-700);
  background-size:cover;background-position:center;
}
.profile-body{padding:0 18px 18px;}
.profile-av-wrap{margin-top:-28px;margin-bottom:10px;}
.profile-av{
  width:56px;height:56px;border-radius:50%;
  border:3px solid var(--navy-800);
  background:var(--navy-700);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:800;color:var(--accent);
  overflow:hidden;flex-shrink:0;
}
.profile-av img{width:100%;height:100%;object-fit:cover;}
.profile-name{font-size:1rem;font-weight:700;margin-bottom:2px;}
.profile-role{font-size:.71rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;}
.about-bio{font-size:.92rem;color:var(--muted);line-height:1.8;margin-bottom:18px;}
.about-bio p+p{margin-top:9px;}
.tags{display:flex;flex-wrap:wrap;gap:7px;}
.tag{
  padding:4px 12px;border-radius:6px;
  background:rgba(96,165,250,.08);border:1px solid rgba(96,165,250,.18);
  color:var(--accent);font-size:.77rem;font-weight:500;
  transition:background var(--ease);
}
.tag:hover{background:rgba(96,165,250,.15);}

/* ═══ COMMUNITY ══════════════════════════════════════════ */
.comm-desc{font-size:.93rem;color:var(--muted);line-height:1.78;margin-bottom:36px;}
.comm-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.comm-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:26px;
  position:relative;overflow:hidden;
  transition:border-color var(--ease),transform var(--ease);
}
.comm-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--blue-500),var(--sky));
}
.comm-card:hover{border-color:var(--border-h);transform:translateY(-3px);}
.comm-icon{font-size:1.8rem;margin-bottom:12px;}
.comm-card-title{font-size:1.05rem;font-weight:700;color:var(--white);margin-bottom:9px;}
.comm-card-body{font-size:.86rem;color:var(--muted);line-height:1.75;}

/* ═══ MEMBERS ════════════════════════════════════════════ */
.members-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px;}
.member-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;cursor:pointer;
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease);
}
.member-card:hover{
  border-color:var(--border-h);
  box-shadow:0 8px 30px rgba(0,0,0,.4);
  transform:translateY(-4px);
}
.mc-banner{
  height:75px;
  background-color:var(--navy-700);
  background-size:cover;background-position:center;
}
.mc-body{padding:0 15px 16px;display:grid;grid-template-columns:1fr 1fr;gap:0 12px;}
.mc-left{min-width:0;}
.mc-av{
  width:52px;height:52px;border-radius:50%;
  border:3px solid var(--navy-800);margin:-26px 0 9px;
  background:var(--navy-700);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;font-weight:800;color:var(--accent);
  overflow:hidden;
}
.mc-av img{width:100%;height:100%;object-fit:cover;}
.mc-name{font-size:.9rem;font-weight:700;margin-bottom:1px;line-height:1.3;}
.mc-nick{font-size:.7rem;color:var(--muted);margin-bottom:7px;}
.mc-role{
  display:inline-block;padding:2px 9px;border-radius:99px;
  background:rgba(96,165,250,.1);border:1px solid rgba(96,165,250,.2);
  color:var(--accent);font-size:.66rem;font-weight:600;margin-bottom:10px;
}
.mc-soc{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.soc{
  width:28px;height:28px;border-radius:6px;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:all var(--ease);
}
.soc:hover{background:rgba(96,165,250,.1);border-color:rgba(96,165,250,.3);color:var(--accent);transform:translateY(-1px);}
.soc.wa:hover{border-color:rgba(34,197,94,.4);color:#22c55e;}
.soc.ig:hover{border-color:rgba(236,72,153,.4);color:#ec4899;}
.soc.tt:hover{border-color:rgba(56,189,248,.4);color:var(--sky);}

/* Bio visible on card */
.mc-bio{
  font-size:.7rem;color:var(--muted);line-height:1.55;
  margin-top:7px;margin-bottom:6px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
}

/* Verified badge */
.mc-verified{
  display:inline-flex;align-items:center;gap:3px;
  font-size:.6rem;font-weight:700;color:#60a5fa;
  margin-left:5px;vertical-align:middle;
}

/* Game list on right side of member card */
.mc-right{
  padding-top:14px;border-left:1px solid var(--border);
  padding-left:12px;min-width:0;
}
.mc-right-label{
  font-size:.58rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);margin-bottom:7px;opacity:.7;
}
.mc-game-item{
  display:flex;flex-direction:column;
  margin-bottom:8px;
}
.mc-game-name{
  font-size:.7rem;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.mc-game-uid{
  font-size:.62rem;color:var(--muted);font-family:monospace;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.mc-no-games{
  font-size:.68rem;color:var(--muted);opacity:.6;font-style:italic;
}

.grid-load{
  grid-column:1/-1;display:flex;align-items:center;
  justify-content:center;gap:12px;padding:60px;
  color:var(--muted);font-size:.84rem;
}
.spin{
  width:22px;height:22px;
  border:2px solid var(--border);border-top-color:var(--accent);
  border-radius:50%;animation:spinning .7s linear infinite;
}
@keyframes spinning{to{transform:rotate(360deg)}}

/* ═══ JOIN ═══════════════════════════════════════════════ */
.join-box{max-width:520px;margin:0 auto;text-align:center;}
.join-box .sec-body{margin:0 auto 32px;}
.join-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ═══ CONTACT ════════════════════════════════════════════ */
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:44px;align-items:start;}
.contact-info .sec-body{margin-bottom:22px;}
.c-links{display:flex;flex-direction:column;gap:9px;}
.c-link{
  display:flex;align-items:center;gap:11px;
  padding:12px 15px;background:var(--bg-card);
  border:1px solid var(--border);border-radius:var(--r);
  font-size:.84rem;color:var(--muted);transition:all var(--ease);
}
.c-link:hover{border-color:var(--border-h);color:var(--white);background:rgba(96,165,250,.05);transform:translateX(3px);}
.c-link-ico{
  width:34px;height:34px;border-radius:8px;background:var(--navy-700);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--muted);transition:color var(--ease);
}
.c-link-ico svg{width:18px;height:18px;}
.c-link:hover .c-link-ico{color:var(--white);}
.c-link-ico.discord{background:#5865f2;color:#fff;}
.c-link-ico.wa{background:#22c55e;color:#fff;}
.c-link:hover .c-link-ico.discord{color:#fff;}
.c-link:hover .c-link-ico.wa{color:#fff;}
.c-link-ico.ig{background:rgba(236,72,153,.12);color:#ec4899;}
.c-link-ico.gh{background:rgba(255,255,255,.07);color:var(--muted);}
.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:26px;}
.fg{margin-bottom:14px;}
.fg label{display:block;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;}
.fg input,.fg textarea{
  width:100%;background:var(--bg-input);
  border:1px solid var(--border);border-radius:var(--r);
  padding:10px 13px;color:var(--white);
  font-family:inherit;font-size:.87rem;
  outline:none;transition:border-color var(--ease),box-shadow var(--ease);resize:none;
}
.fg input:focus,.fg textarea:focus{border-color:rgba(96,165,250,.4);box-shadow:0 0 0 3px rgba(96,165,250,.09);}
.fg textarea{min-height:108px;}
.form-note{font-size:.69rem;color:var(--muted);text-align:center;margin-top:10px;}

/* ═══ FOOTER ═════════════════════════════════════════════ */
footer{background:var(--navy-900);border-top:1px solid var(--border);padding:34px 0;text-align:center;}
.footer-name{font-size:1.05rem;font-weight:700;margin-bottom:5px;}
.footer-tag{font-size:.8rem;color:var(--muted);margin-bottom:18px;}
.footer-div{width:36px;height:1px;background:var(--border);margin:0 auto 14px;}
.footer-copy{font-size:.7rem;color:var(--muted);opacity:.5;}

/* ═══ MEMBER MODAL ═══════════════════════════════════════ */
.overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.6);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;pointer-events:none;transition:opacity .22s;
}
.overlay.show{opacity:1;pointer-events:all;}
.modal{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-xl);width:100%;max-width:420px;
  max-height:88svh;overflow-y:auto;
  transform:scale(.94) translateY(14px);
  transition:transform .28s cubic-bezier(.34,1.3,.64,1);
  position:relative;
}
.overlay.show .modal{transform:scale(1) translateY(0);}
.modal-x{
  position:absolute;top:11px;right:11px;z-index:1;
  width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,.07);border:none;
  color:var(--muted);font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:var(--ease);
}
.modal-x:hover{background:rgba(248,113,113,.2);color:var(--red);}
.modal-banner{
  height:110px;
  background-color:var(--navy-700);
  background-image:linear-gradient(135deg,var(--navy-700),var(--navy-600));
  background-size:cover;background-position:center;
  border-radius:var(--r-xl) var(--r-xl) 0 0;
}
.modal-cnt{padding:0 22px 22px;}
.m-av{
  width:68px;height:68px;border-radius:50%;
  border:3px solid var(--bg-card);margin:-34px 0 12px;
  background:var(--navy-700);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;font-weight:800;color:var(--accent);overflow:hidden;
}
.m-av img{width:100%;height:100%;object-fit:cover;}
.m-name{font-size:1.2rem;font-weight:800;margin-bottom:3px;}
.m-handle{font-size:.76rem;color:var(--muted);margin-bottom:9px;}
.m-role-b{
  display:inline-block;padding:3px 11px;border-radius:99px;
  background:rgba(96,165,250,.1);border:1px solid rgba(96,165,250,.22);
  color:var(--accent);font-size:.73rem;font-weight:600;margin-bottom:12px;
}
.m-bio{font-size:.86rem;color:var(--muted);line-height:1.75;margin-bottom:14px;}
.m-soc{display:flex;gap:8px;margin-bottom:12px;}
.m-joined{font-size:.7rem;color:var(--muted);}
.m-joined span{color:var(--accent);}

/* ═══ ICON UTIL ══════════════════════════════════════════ */
.ico{
  width:15px;height:15px;fill:none;stroke:currentColor;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  display:inline-block;vertical-align:middle;flex-shrink:0;
}
.ico.f{fill:currentColor;stroke:none;}

/* ═══ KEYFRAMES ══════════════════════════════════════════ */
@keyframes fadeup{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* ═══ RESPONSIVE ═════════════════════════════════════════ */
@media(max-width:900px){
  .nav-links{display:none;} .burger{display:flex;}
  .about-layout{grid-template-columns:1fr;}
  .profile-card{max-width:280px;}
  .comm-grid{grid-template-columns:1fr;}
  .members-grid{grid-template-columns:repeat(2,1fr);}
  .contact-layout{grid-template-columns:1fr;}
  .stats-row{grid-template-columns:repeat(2,1fr);}
  .stat-cell:nth-child(2){border-right:none;}
  .stat-cell:nth-child(3){border-top:1px solid var(--border);}
  .stat-cell:nth-child(4){border-top:1px solid var(--border);border-right:none;}
}
@media(max-width:540px){
  .section{padding:56px 0;}
  .members-grid{grid-template-columns:1fr;}
  .hero-btns{flex-direction:column;}
  .hero-btns .btn{width:100%;justify-content:center;}
  .join-btns{flex-direction:column;align-items:stretch;}
  .join-btns .btn{width:100%;justify-content:center;}
}

/* ═══ NAV RIGHT ══════════════════════════════════════════ */
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.nav-user-btn{
  display:flex;align-items:center;gap:7px;
  padding:5px 12px;border-radius:var(--r);
  background:rgba(96,165,250,.1);border:1px solid rgba(96,165,250,.2);
  color:var(--accent);font-size:.77rem;font-weight:600;
  white-space:nowrap;max-width:130px;overflow:hidden;text-overflow:ellipsis;
  transition:all var(--ease);
}
.nav-user-btn:hover{background:rgba(96,165,250,.18);}
.nav-user-av{
  width:22px;height:22px;border-radius:50%;
  background:var(--navy-700);display:flex;align-items:center;
  justify-content:center;font-size:.6rem;font-weight:700;color:var(--accent);
  overflow:hidden;flex-shrink:0;
}
.nav-user-av img{width:100%;height:100%;object-fit:cover;}
.nav-logout-btn{
  padding:5px 10px;border-radius:var(--r);
  background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2);
  color:var(--red);font-size:.73rem;font-weight:600;cursor:pointer;
  white-space:nowrap;
  transition:all var(--ease);
}
.nav-logout-btn:hover{background:rgba(248,113,113,.18);}
/* On mobile: hide nav user area completely, use drawer instead */
@media(max-width:900px){
  #nav-user-area { display: none; }
}
@media(max-width:540px){
  .nav-user-name-text{display:none;}
  .nav-logout-btn{padding:5px 8px;font-size:.68rem;}
}
.nav-ver-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:50%;
  background:#3b82f6;flex-shrink:0;
  box-shadow:0 0 0 2px rgba(59,130,246,.25);
}
.drawer-divider{height:1px;background:var(--border);margin:8px 0;}

/* ═══ HERO SLIDESHOW ═════════════════════════════════════ */
.hero-inner{position:relative;z-index:1;max-width:500px;}
#hero .wrap{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:40px;
}
.hero-slideshow{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  aspect-ratio:4/3;background:var(--navy-800);
  border:1px solid var(--border);
  animation:fadeup .9s .4s ease both;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.slideshow-track{width:100%;height:100%;position:relative;}
.slideshow-track .slide{
  position:absolute;inset:0;opacity:0;transition:opacity .6s ease;
}
.slideshow-track .slide.active{opacity:1;}
.slideshow-track .slide img{width:100%;height:100%;object-fit:cover;}
.slide-info{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(0,0,0,.85),transparent);
  padding:28px 14px 12px;
}
.slide-info-title{font-size:.82rem;font-weight:700;color:#fff;margin-bottom:3px;}
.slide-info-meta{font-size:.68rem;color:rgba(255,255,255,.6);}
.slide-placeholder{
  width:100%;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:8px;
  color:var(--muted);
}
.slide-ph-icon{font-size:2.5rem;opacity:.4;}
.slide-ph-text{font-size:.8rem;text-align:center;line-height:1.5;opacity:.6;}
.slideshow-dots{
  position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
  display:flex;gap:5px;z-index:2;
}
.slideshow-dots .dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,.3);cursor:pointer;transition:all .2s;
}
.slideshow-dots .dot.active{background:#fff;width:18px;border-radius:3px;}
.slide-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:32px;height:32px;border-radius:50%;border:none;
  background:rgba(0,0,0,.5);color:#fff;font-size:1.2rem;
  cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;
  transition:background .2s;opacity:0;
}
.hero-slideshow:hover .slide-btn{opacity:1;}
.slide-btn:hover{background:rgba(0,0,0,.8);}
.slide-prev{left:8px;}
.slide-next{right:8px;}

/* ═══ AUTH MODAL ══════════════════════════════════════════ */
.auth-modal{max-width:380px;padding:0;}
.auth-tabs{
  display:flex;border-bottom:1px solid var(--border);
  padding:0 8px;gap:4px;margin-top:8px;
}
.auth-tab{
  padding:10px 18px;background:none;border:none;
  color:var(--muted);font-size:.82rem;font-weight:600;cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:all var(--ease);
}
.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent);}
.auth-body{padding:22px 24px 26px;}
.auth-icon{display:flex;align-items:center;justify-content:center;margin-bottom:10px;color:var(--accent);opacity:.85;}
.auth-icon svg{width:38px;height:38px;}
.auth-title{font-size:1.1rem;font-weight:800;text-align:center;margin-bottom:4px;}
.auth-sub{font-size:.8rem;color:var(--muted);text-align:center;margin-bottom:18px;}
.auth-msg{
  font-size:.78rem;padding:8px 11px;border-radius:7px;
  margin-bottom:12px;display:none;
}
.auth-msg.err{display:block;background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.2);color:var(--red);}
.auth-msg.ok{display:block;background:rgba(74,222,128,.1);border:1px solid rgba(74,222,128,.2);color:var(--green);}
.auth-msg.info{display:block;background:rgba(96,165,250,.1);border:1px solid rgba(96,165,250,.2);color:var(--accent);}
.auth-switch{font-size:.77rem;color:var(--muted);text-align:center;margin-top:14px;}
.auth-switch a{color:var(--accent);cursor:pointer;text-decoration:underline;}
.auth-otp-info{
  background:rgba(96,165,250,.07);border:1px solid rgba(96,165,250,.15);
  border-radius:var(--r);padding:14px;text-align:center;margin-bottom:16px;
}
.otp-icon{display:flex;align-items:center;justify-content:center;margin-bottom:8px;color:var(--accent);}
.otp-icon svg{width:32px;height:32px;}
.auth-otp-info p{font-size:.82rem;color:var(--muted);}

/* Dev OTP box */
.dev-otp-box{
  background:rgba(234,179,8,.08);border:1px solid rgba(234,179,8,.25);
  border-radius:var(--r);padding:10px 14px;margin-bottom:12px;
  font-size:.8rem;color:#fbbf24;display:none;
}
.dev-otp-box.show{display:block;}
.dev-otp-code{font-size:1.4rem;font-weight:800;letter-spacing:.15em;text-align:center;margin-top:4px;}

/* ═══ GALLERY PAGE ════════════════════════════════════════ */
.gallery-hero{
  padding:110px 0 50px;
  background:var(--navy-900);border-bottom:1px solid var(--border);
}
.gallery-controls-bar{
  position:sticky;top:60px;z-index:50;
  background:rgba(5,13,26,.94);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);padding:10px 0;
}
.gallery-controls-inner{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.gallery-cats{display:flex;gap:6px;flex-wrap:wrap;flex:1;}
.cat-btn{
  padding:5px 14px;border-radius:99px;border:1px solid var(--border);
  background:transparent;color:var(--muted);font-size:.77rem;font-weight:600;
  cursor:pointer;transition:all var(--ease);white-space:nowrap;
}
.cat-btn.active,.cat-btn:hover{
  background:rgba(96,165,250,.1);border-color:rgba(96,165,250,.3);color:var(--accent);
}
.gallery-page-wrap{padding:36px 0 60px;}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:16px;
}
.gallery-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;cursor:pointer;
  transition:border-color var(--ease),transform var(--ease),box-shadow var(--ease);
}
.gallery-card:hover{
  border-color:var(--border-h);transform:translateY(-4px);
  box-shadow:0 12px 36px rgba(0,0,0,.4);
}
.gallery-card-img{
  aspect-ratio:4/3;background:var(--navy-700);
  background-size:cover;background-position:center;
  position:relative;overflow:hidden;
}
.gallery-card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 50%);
  opacity:0;transition:opacity .2s;
}
.gallery-card:hover .gallery-card-img::after{opacity:1;}
.gallery-card-body{padding:12px 14px;}
.gallery-card-title{font-size:.85rem;font-weight:700;margin-bottom:4px;line-height:1.3;}
.gallery-card-meta{font-size:.7rem;color:var(--muted);}
.gallery-cat-badge{
  display:inline-block;padding:2px 8px;border-radius:99px;
  background:rgba(96,165,250,.08);border:1px solid rgba(96,165,250,.16);
  color:var(--accent);font-size:.63rem;font-weight:600;margin-top:6px;
}
.gallery-pagination{display:flex;justify-content:center;gap:8px;margin-top:28px;}
.page-btn{
  padding:6px 14px;border-radius:var(--r);border:1px solid var(--border);
  background:var(--bg-card);color:var(--muted);font-size:.78rem;
  cursor:pointer;transition:all var(--ease);
}
.page-btn.active,.page-btn:hover{
  background:rgba(96,165,250,.1);border-color:rgba(96,165,250,.3);color:var(--accent);
}
.gallery-empty{
  grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--muted);
}
.gallery-empty-icon{font-size:3rem;margin-bottom:12px;}

/* ═══ LIGHTBOX ════════════════════════════════════════════ */
.lightbox-modal{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-xl);width:100%;max-width:700px;
  max-height:92svh;overflow-y:auto;position:relative;
}
#lb-img{width:100%;max-height:480px;object-fit:contain;background:var(--navy-900);border-radius:var(--r-xl) var(--r-xl) 0 0;}
.lb-info{padding:16px 20px;}
.lb-title{font-size:1rem;font-weight:700;margin-bottom:6px;}
.lb-meta{font-size:.77rem;color:var(--muted);}
.lb-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;}
.lb-tag{
  padding:3px 10px;border-radius:99px;background:rgba(96,165,250,.08);
  border:1px solid rgba(96,165,250,.16);color:var(--accent);font-size:.7rem;
}
.lb-delete{margin:0 20px 16px;}

/* ═══ UPLOAD MODAL ════════════════════════════════════════ */
.upload-modal{max-width:460px;}
.upload-drop-zone{
  border:2px dashed var(--border);border-radius:var(--r-lg);
  padding:28px;text-align:center;cursor:pointer;
  transition:all var(--ease);
}
.upload-drop-zone:hover{border-color:var(--accent);background:rgba(96,165,250,.04);}
.upload-drop-icon{display:flex;align-items:center;justify-content:center;margin-bottom:8px;color:var(--accent);opacity:.6;}
.upload-drop-icon svg{width:44px;height:44px;}
.upload-drop-text{font-size:.84rem;font-weight:600;color:var(--muted);}
.fg-select{
  width:100%;background:var(--bg-input);border:1px solid var(--border);
  border-radius:var(--r);padding:10px 13px;color:var(--white);
  font-family:inherit;font-size:.87rem;outline:none;
  transition:border-color var(--ease);
}
.fg-select:focus{border-color:rgba(96,165,250,.4);}
.tag-picker{display:flex;flex-wrap:wrap;gap:6px;}
.tag-pick-btn{
  padding:4px 11px;border-radius:99px;border:1px solid var(--border);
  background:transparent;color:var(--muted);font-size:.74rem;cursor:pointer;
  transition:all var(--ease);
}
.tag-pick-btn.selected{
  background:rgba(96,165,250,.1);border-color:rgba(96,165,250,.3);color:var(--accent);
}

/* ═══ RESPONSIVE ADDITIONS ════════════════════════════════ */
@media(max-width:900px){
  #hero .wrap{grid-template-columns:1fr;}
  .hero-slideshow{max-width:480px;margin:0 auto;}
  .hero-inner{max-width:100%;}
}
@media(max-width:540px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .hero-slideshow{display:none;} /* hide on mobile, text takes full width */
}

/* ═══════════════════════════════════════════════════════════
   VERIFIED BADGE (Centang Biru)
═══════════════════════════════════════════════════════════ */
.nav-ver-badge,.ver-badge-sm{
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#3b82f6,#0ea5e9);
  box-shadow:0 0 6px rgba(59,130,246,0.4);
}
.ver-badge-sm{width:13px;height:13px;margin-left:3px;vertical-align:middle;}

.nav-user-btn{
  display:flex;align-items:center;gap:7px;font-size:.78rem;font-weight:500;
  color:var(--muted);padding:5px 10px;border-radius:8px;transition:var(--ease);white-space:nowrap;
}
.nav-user-btn:hover{color:var(--white);background:rgba(255,255,255,.06);}
.nav-user-av{
  width:26px;height:26px;border-radius:50%;flex-shrink:0;overflow:hidden;
  background:var(--navy-600);display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:700;color:var(--accent);
}
.nav-user-av img{width:100%;height:100%;object-fit:cover;}
.nav-user-name-text{max-width:120px;overflow:hidden;text-overflow:ellipsis;}
.nav-logout-btn{
  background:none;border:none;color:var(--muted);font-size:.7rem;padding:5px 8px;
  border-radius:6px;transition:var(--ease);
}
.nav-logout-btn:hover{color:var(--red);background:rgba(248,113,113,.1);}

/* Nav right area */
.nav-right{display:flex;align-items:center;gap:4px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:99px;padding:3px 4px 3px 3px;}
.nav-right .nav-user-btn{border-radius:99px;padding:4px 10px 4px 4px;}
.nav-right .nav-logout-btn{font-size:.65rem;opacity:.5;padding:4px 8px;border-radius:99px;}
.nav-right .nav-logout-btn:hover{opacity:1;}
.nav-right .nav-logout-btn::before{content:'·';margin-right:4px;opacity:.4;}

/* ═══════════════════════════════════════════════════════════
   GALLERY CARDS — enhanced with like icon
═══════════════════════════════════════════════════════════ */
.gallery-card-footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:6px;
}
.gallery-card-user{
  font-size:.7rem;color:var(--muted);transition:color var(--ease);
}
.gallery-card-user:hover{color:var(--accent);}
.gallery-card-actions{display:flex;align-items:center;gap:8px;}
.gallery-card-like{
  display:flex;align-items:center;gap:3px;font-size:.72rem;color:var(--muted);
}
.gallery-card-like.liked{color:var(--red);}

/* ═══════════════════════════════════════════════════════════
   LIGHTBOX — enhanced with comments panel
═══════════════════════════════════════════════════════════ */
.lightbox-modal{
  position:relative;background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-xl);max-width:860px;width:95%;max-height:92vh;
  overflow-y:auto;display:flex;flex-direction:column;
}
.lightbox-modal .modal-x{
  position:absolute;top:12px;right:12px;z-index:10;
  background:rgba(0,0,0,.55);border:none;color:#fff;width:32px;height:32px;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.9rem;transition:var(--ease);
}
.lightbox-modal .modal-x:hover{background:rgba(0,0,0,.8);}
#lb-img{width:100%;max-height:55vh;object-fit:contain;border-radius:var(--r-xl) var(--r-xl) 0 0;background:#000;}
.lb-info{padding:18px 22px 20px;}
.lb-top-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.lb-title{font-size:1.05rem;font-weight:700;}
.lb-meta{font-size:.75rem;color:var(--muted);margin-top:3px;}
.lb-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;}
.lb-tag{
  font-size:.7rem;color:var(--accent);background:rgba(96,165,250,.1);
  padding:3px 10px;border-radius:99px;transition:var(--ease);
}
.lb-tag:hover{background:rgba(96,165,250,.2);}

/* Like button in lightbox */
.lb-like-btn{
  display:flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.06);border:1px solid var(--border);
  color:var(--muted);padding:7px 14px;border-radius:99px;
  font-size:.8rem;font-weight:600;transition:var(--ease);flex-shrink:0;
}
.lb-like-btn:hover{background:rgba(255,255,255,.1);border-color:var(--border-h);}
.lb-like-btn.liked{color:var(--red);border-color:rgba(248,113,113,.3);background:rgba(248,113,113,.08);}

/* Delete button in lightbox */
.lb-delete{
  margin:0 22px 16px;align-self:flex-start;
}

/* ═══════════════════════════════════════════════════════════
   COMMENTS in lightbox
═══════════════════════════════════════════════════════════ */
.lb-comments-section{
  margin-top:16px;border-top:1px solid var(--border);padding-top:14px;
}
.lb-comments-head{
  display:flex;align-items:center;gap:7px;font-size:.82rem;font-weight:600;
  color:var(--muted);margin-bottom:12px;
}
.lb-comments-head .ico{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.lb-comment-count{font-weight:400;font-size:.75rem;}
.lb-comments-list{
  max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;
  padding-right:4px;
}
.lb-comments-empty{font-size:.78rem;color:var(--muted);text-align:center;padding:16px 0;}

.lb-comment{display:flex;gap:10px;align-items:flex-start;}
.lb-comment-av{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:var(--navy-600);display:flex;align-items:center;justify-content:center;
  font-size:.68rem;font-weight:700;color:var(--accent);
}
.lb-comment-body{flex:1;min-width:0;}
.lb-comment-head{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.lb-comment-name{
  font-size:.76rem;font-weight:600;color:var(--accent);
  display:inline-flex;align-items:center;gap:3px;
}
.lb-comment-name:hover{text-decoration:underline;}
.lb-comment-time{font-size:.66rem;color:var(--muted);}
.lb-comment-del{
  background:none;border:none;color:var(--muted);font-size:.7rem;
  padding:0 4px;opacity:0;transition:var(--ease);cursor:pointer;
}
.lb-comment:hover .lb-comment-del{opacity:1;}
.lb-comment-del:hover{color:var(--red);}
.lb-comment-text{font-size:.8rem;color:var(--white);margin-top:2px;word-break:break-word;}

/* Comment input */
.lb-comment-form{
  display:flex;align-items:center;gap:8px;margin-top:12px;
}
.lb-comment-input{
  flex:1;background:var(--bg-input);border:1px solid var(--border);
  color:var(--text);padding:9px 14px;border-radius:99px;font-size:.8rem;
  font-family:inherit;outline:none;transition:var(--ease);
}
.lb-comment-input:focus{border-color:var(--border-h);}
.lb-comment-input::placeholder{color:var(--muted);}
.lb-comment-send{
  width:36px;height:36px;border-radius:50%;border:none;flex-shrink:0;
  background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;
  transition:var(--ease);
}
.lb-comment-send:hover{background:var(--blue-600);transform:scale(1.05);}
.lb-comment-login{
  font-size:.78rem;color:var(--muted);text-align:center;margin-top:12px;
}

/* ═══════════════════════════════════════════════════════════
   UPLOAD MODAL — enhanced
═══════════════════════════════════════════════════════════ */
.upload-modal{max-width:520px;width:95%;max-height:90vh;overflow-y:auto;}
.upload-drop-zone{
  background:var(--bg-input);border:2px dashed var(--border);
  border-radius:var(--r-lg);padding:36px 20px;text-align:center;
  cursor:pointer;transition:var(--ease);
}
.upload-drop-zone:hover,.upload-drop-zone.drag-over{border-color:var(--accent);background:rgba(96,165,250,.05);}
.upload-drop-icon{margin:0 auto 10px;}
.upload-drop-icon svg{width:40px;height:40px;color:var(--muted);}
.upload-drop-text{font-size:.85rem;font-weight:600;color:var(--muted);}
.fg-select{
  width:100%;background:var(--bg-input);border:1px solid var(--border);
  color:var(--text);padding:10px 14px;border-radius:var(--r);font-size:.85rem;
  font-family:inherit;outline:none;transition:var(--ease);appearance:none;
}
.fg-select:focus{border-color:var(--border-h);}
.tag-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;}
.tag-member-label{
  display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--muted);
  background:var(--bg-input);padding:4px 10px;border-radius:99px;cursor:pointer;
  transition:var(--ease);border:1px solid var(--border);
}
.tag-member-label:hover{border-color:var(--border-h);color:var(--accent);}
.tag-member-cb{display:none;}
.tag-member-cb:checked + span{color:var(--accent);}
.tag-member-cb:checked ~ *{color:var(--accent);}
.tag-member-label:has(.tag-member-cb:checked){border-color:var(--accent);background:rgba(96,165,250,.1);}

/* ═══════════════════════════════════════════════════════════
   PROFILE PAGE
═══════════════════════════════════════════════════════════ */
.profile-page{padding-top:60px;min-height:100vh;}
.profile-page-header{
  background:linear-gradient(180deg,var(--navy-800) 0%,var(--bg) 100%);
  padding-bottom:24px;
}
.profile-hero-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;margin-top:24px;
}
.profile-hero-banner{
  height:120px;
  background-color:var(--navy-800);
  background-image:linear-gradient(135deg,var(--navy-700) 0%,var(--navy-800) 40%,rgba(59,130,246,.15) 100%);
  background-size:cover;background-position:center;
}
.profile-hero-body{
  display:flex;align-items:flex-end;gap:16px;padding:0 24px 20px;
  flex-wrap:wrap;margin-top:-36px;position:relative;
}
.profile-hero-av{
  width:80px;height:80px;border-radius:50%;flex-shrink:0;overflow:hidden;
  background:var(--navy-600);border:4px solid var(--bg-card);
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;font-weight:800;color:var(--accent);
}
.profile-hero-av img{width:100%;height:100%;object-fit:cover;}
.profile-hero-info{flex:1;min-width:0;padding-top:8px;}
.profile-hero-name{
  display:flex;align-items:center;gap:8px;
  font-size:1.2rem;font-weight:800;
}
.profile-ver-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,#3b82f6,#0ea5e9);
  box-shadow:0 0 8px rgba(59,130,246,0.5);
}
.profile-hero-handle{font-size:.8rem;color:var(--muted);margin-top:2px;}
.profile-hero-role{
  font-size:.72rem;color:var(--accent);background:rgba(96,165,250,.1);
  padding:3px 10px;border-radius:99px;display:inline-block;margin-top:6px;
}
.profile-hero-actions{
  display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;
}

/* Profile grid layout */
.profile-content{padding:24px 0 60px;}
.profile-grid{display:grid;grid-template-columns:1fr;gap:20px;max-width:640px;}
@media(min-width:900px){
  .profile-grid{grid-template-columns:320px 1fr;max-width:none;}
}

.profile-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px 20px;margin-bottom:16px;
}
.profile-card-head{
  display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;
  color:var(--muted);margin-bottom:14px;
}
.profile-card-head .ico{
  width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;
}
.profile-card-mini{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:12px 16px;margin-bottom:16px;
  display:flex;align-items:center;gap:8px;font-size:.76rem;color:var(--muted);
}

.profile-bio{font-size:.84rem;color:var(--white);line-height:1.6;}
.profile-bio-empty{color:var(--muted);font-style:italic;}
.profile-bio-input{
  width:100%;min-height:80px;background:var(--bg-input);
  border:1px solid var(--border);color:var(--text);
  padding:10px 14px;border-radius:var(--r);font-size:.84rem;
  font-family:inherit;outline:none;resize:vertical;
}
.profile-bio-input:focus{border-color:var(--border-h);}

.profile-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.profile-stat{text-align:center;padding:10px 6px;background:var(--bg-input);border-radius:var(--r);}
.profile-stat-num{font-size:1.2rem;font-weight:800;color:var(--accent);}
.profile-stat-label{font-size:.68rem;color:var(--muted);margin-top:2px;}

.profile-member-name{font-size:.85rem;font-weight:600;margin-bottom:8px;}
.profile-games-label{font-size:.72rem;color:var(--muted);margin-top:10px;margin-bottom:6px;}
.profile-game-item{
  font-size:.78rem;color:var(--white);padding:5px 12px;
  background:var(--bg-input);border-radius:var(--r);margin-bottom:4px;
  display:flex;align-items:center;gap:6px;
}
.profile-game-item::before{content:'🎮';font-size:.7rem;}

/* Profile photos grid */
.profile-photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.profile-photos-empty{
  grid-column:1/-1;text-align:center;padding:30px;font-size:.8rem;color:var(--muted);
}
.profile-photo-card{
  border-radius:var(--r);overflow:hidden;background:var(--bg-input);
  border:1px solid var(--border);transition:var(--ease);cursor:pointer;
}
.profile-photo-card:hover{border-color:var(--border-h);transform:translateY(-2px);}
.profile-photo-img{
  width:100%;aspect-ratio:1;background-size:cover;background-position:center;
}
.profile-photo-title{
  padding:8px 10px;font-size:.72rem;font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* Disabled button style */
.btn-disabled, .btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

/* Profile page responsive */
@media(max-width:768px){
  .profile-grid{grid-template-columns:1fr;max-width:none;}
  .profile-left,.profile-right{width:100%;}
  .profile-hero-body{
    padding:0 16px 16px;
    flex-direction:column;
    align-items:center;
    text-align:center;
    padding-top:0;
  }
  .profile-hero-info{padding-top:4px;text-align:center;}
  .profile-hero-name{justify-content:center;}
  .profile-hero-actions{justify-content:center;}
  .profile-hero-av{width:64px;height:64px;font-size:1.2rem;}
  .profile-hero-name{font-size:1rem;}
  .profile-photos-grid{grid-template-columns:repeat(2,1fr);}
}

/* ═══════════════════════════════════════════════════════════
   GALLERY PAGE — hero section
═══════════════════════════════════════════════════════════ */
.gallery-hero{
  padding:100px 0 40px;
  background:linear-gradient(180deg,var(--navy-800) 0%,var(--bg) 100%);
}
.gallery-controls-bar{
  background:var(--bg);border-bottom:1px solid var(--border);
  padding:14px 0;position:sticky;top:60px;z-index:50;
  backdrop-filter:blur(12px);
}
.gallery-controls-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.gallery-cats{display:flex;gap:6px;overflow-x:auto;flex:1;padding:2px 0;}
.gallery-cats::-webkit-scrollbar{height:0;}
.cat-btn{
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  color:var(--muted);padding:6px 16px;border-radius:99px;
  font-size:.76rem;font-weight:500;font-family:inherit;
  white-space:nowrap;transition:var(--ease);
}
.cat-btn:hover{border-color:var(--border-h);color:var(--white);}
.cat-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);}

.gallery-page-wrap{padding:30px 0 60px;}
.gallery-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:16px;min-height:200px;
}
.gallery-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;cursor:pointer;
  transition:var(--ease);
}
.gallery-card:hover{border-color:var(--border-h);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.3);}
.gallery-card-img{
  width:100%;aspect-ratio:4/3;background-size:cover;background-position:center;
}
.gallery-card-body{padding:12px 14px;}
.gallery-card-title{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.gallery-empty{
  grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--muted);
}
.grid-load{
  grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--muted);
  display:flex;flex-direction:column;align-items:center;gap:12px;
}

/* Pagination */
.gallery-pagination{display:flex;justify-content:center;gap:6px;margin-top:30px;}
.page-btn{
  background:var(--bg-card);border:1px solid var(--border);color:var(--muted);
  padding:7px 14px;border-radius:var(--r);font-size:.78rem;font-family:inherit;
  transition:var(--ease);
}
.page-btn:hover{border-color:var(--border-h);color:var(--white);}
.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.page-dots{color:var(--muted);padding:7px 6px;font-size:.78rem;}

/* Spinner */
.spin{
  width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);
  border-radius:50%;animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* Gallery responsive */
@media(max-width:768px){
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;}
  .gallery-controls-inner{flex-direction:column;align-items:stretch;}
  .gallery-controls-inner .btn{align-self:flex-start;width:auto;}
}

/* ── Small util buttons ──────────────────────────────── */
.btn-sm{font-size:.76rem;padding:6px 14px;}
.btn-ghost{background:none;border:1px solid var(--border);color:var(--muted);}
.btn-ghost:hover{border-color:var(--border-h);color:var(--white);}
.btn-danger{background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.3);color:var(--red);}
.btn-danger:hover{background:rgba(248,113,113,.2);}

/* Section helpers */
.sec-eye{
  font-size:.72rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--accent);margin-bottom:8px;
}
.sec-title{font-size:1.8rem;font-weight:800;line-height:1.2;margin-bottom:10px;}
.sec-body{font-size:.9rem;color:var(--muted);max-width:540px;}

/* ═══ TOAST NOTIFICATION ══════════════════════════════════ */
.toast-container{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{
  pointer-events:auto;
  padding:12px 20px;border-radius:var(--r-lg);font-size:.84rem;font-weight:500;
  color:#fff;display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 32px rgba(0,0,0,.5);backdrop-filter:blur(12px);
  animation:toastIn .35s ease forwards;min-width:240px;max-width:400px;
}
.toast.info{background:rgba(59,130,246,.92);}
.toast.warn{background:rgba(234,179,8,.92);color:#1a1a0a;}
.toast.err{background:rgba(248,113,113,.92);}
.toast.ok{background:rgba(34,197,94,.92);}
.toast.hide{animation:toastOut .3s ease forwards;}
@keyframes toastIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes toastOut{from{opacity:1;transform:none}to{opacity:0;transform:translateY(16px)}}
