/* ══════════════════════════════════════════════════
   رسول کرفت — طراحی v5  |  Modern Light
   ══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Vazirmatn:wght@300;400;500;600;700;900&display=swap');

:root {
  /* ── Backgrounds ── */
  --bg:        #F0F2F5;
  --surface:   #FFFFFF;
  --card:      #FFFFFF;
  --card-h:    #F8FAFF;
  --border:    #E4E7EF;
  --border-h:  #C7D0E8;

  /* ── Brand ── */
  --primary:     #2563EB;
  --primary-d:   #1D4ED8;
  --primary-l:   #EFF6FF;
  --primary-m:   #BFDBFE;

  --green:       #16A34A;
  --green-d:     #15803D;
  --green-l:     #F0FDF4;
  --green-m:     #BBF7D0;

  --red:         #DC2626;
  --red-l:       #FEF2F2;
  --red-m:       #FECACA;

  --gold:        #D97706;
  --gold-l:      #FFFBEB;

  --purple:      #7C3AED;
  --purple-l:    #F5F3FF;

  /* compat aliases */
  --teal:        #2563EB;
  --teal-d:      #1D4ED8;
  --teal-glow:   rgba(37,99,235,.12);

  /* ── Text ── */
  --text:        #1E293B;
  --text-2:      #64748B;
  --text-3:      #94A3B8;
  --white:       #FFFFFF;

  /* ── Radius ── */
  --r:           8px;
  --r-lg:        12px;
  --r-xl:        18px;
  --r-pill:      999px;

  /* ── Shadow ── */
  --shadow-sm:   0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow:      0 4px 12px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);
  --shadow-lg:   0 12px 32px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.05);
  --shadow-xl:   0 24px 48px rgba(0,0,0,.12);
}

/* ── RESET ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Vazirmatn',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  direction:rtl;
  line-height:1.7;
  min-height:100vh;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary);text-decoration:none;transition:color .15s}
a:hover{color:var(--primary-d)}
img{max-width:100%}
.tc1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.tc2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tc3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* ── LIVE BANNER ────────────────────────────── */
#live-banner{
  background:linear-gradient(90deg,#991B1B,#DC2626,#B91C1C,#DC2626,#991B1B);
  background-size:300%;animation:liveGrad 5s ease infinite;
  padding:9px 0;font-size:.82rem;font-weight:700;
}
@keyframes liveGrad{0%,100%{background-position:0%}50%{background-position:100%}}
.live-dot{width:8px;height:8px;background:#fff;border-radius:50%;display:inline-block;
  box-shadow:0 0 0 0 rgba(255,255,255,.6);animation:lp 1.4s infinite;}
@keyframes lp{0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}70%{box-shadow:0 0 0 8px transparent}100%{box-shadow:0 0 0 0 transparent}}
.live-pill{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);
  color:#fff;padding:3px 12px;border-radius:var(--r-pill);font-size:.73rem;font-weight:800;letter-spacing:1.5px}

/* ── NAVBAR ─────────────────────────────────── */
.site-nav{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:1000;
  box-shadow:var(--shadow-sm);
}
.nav-inner{display:flex;align-items:center;gap:14px;padding:12px 0;flex-wrap:wrap}

.brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.brand-img{width:36px;height:36px;border-radius:10px;border:2px solid var(--primary-m);object-fit:cover;box-shadow:0 0 0 3px var(--primary-l)}
.brand-txt{font-size:1.1rem;font-weight:900;background:linear-gradient(135deg,var(--primary) 0%,var(--green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.nav-search{flex:1;min-width:180px;max-width:440px;display:flex;align-items:center;
  background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-pill);overflow:hidden;
  transition:border-color .25s ease,background .25s ease,box-shadow .25s ease}
.nav-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-l);background:#fff}
.nav-search input{flex:1;background:transparent;border:none;outline:none;padding:9px 16px;color:var(--text);font-family:inherit;font-size:.88rem}
.nav-search input::placeholder{color:var(--text-3)}
.nav-search button{background:var(--primary);border:none;padding:9px 18px;color:#fff;cursor:pointer;font-size:.85rem;font-family:inherit;font-weight:700;display:flex;align-items:center;gap:5px;flex-shrink:0;transition:background .15s}
.nav-search button:hover{background:var(--primary-d)}

/* ── SUGGEST WRAP ── */
.nav-search-wrap{position:relative;flex:1;min-width:180px;max-width:440px;display:flex}
.nav-search-wrap .nav-search{flex:1;max-width:none;min-width:0}

/* ساجست به‌صورت floating card — سرچ‌بار شکلش تغییر نمی‌کنه */
.search-suggest{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  box-shadow:0 8px 32px -4px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.06);
  z-index:1200;max-height:min(70vh,420px);overflow-y:auto;padding:6px;
  opacity:0;pointer-events:none;visibility:hidden;
  transform:translateY(-6px);
  transition:opacity .22s ease,transform .22s ease,visibility 0s .22s}
.nav-search-wrap:has(.big-search) .search-suggest{border-radius:var(--r-xl);top:calc(100% + 8px)}
.search-suggest.open{
  opacity:1;pointer-events:auto;visibility:visible;transform:translateY(0);
  transition:opacity .22s ease,transform .22s ease,visibility 0s 0s}
/* hide scrollbar but keep scrolling */
.search-suggest{scrollbar-width:none;-ms-overflow-style:none}
.search-suggest::-webkit-scrollbar{width:0;height:0;display:none}

/* rows */
.ss-item{display:flex;align-items:center;gap:11px;padding:8px 10px;cursor:pointer;
  text-decoration:none;color:var(--text);border-radius:10px;
  transition:background .15s ease}
/* stagger only on the FIRST open (class added by JS), not on every keystroke */
.search-suggest.fresh .ss-item{opacity:0;animation:ssItemIn .26s ease forwards}
.search-suggest.fresh .ss-item:nth-child(1){animation-delay:.02s}
.search-suggest.fresh .ss-item:nth-child(2){animation-delay:.05s}
.search-suggest.fresh .ss-item:nth-child(3){animation-delay:.08s}
.search-suggest.fresh .ss-item:nth-child(4){animation-delay:.11s}
.search-suggest.fresh .ss-item:nth-child(5){animation-delay:.14s}
.search-suggest.fresh .ss-item:nth-child(n+6){animation-delay:.17s}
@keyframes ssItemIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){
  .search-suggest{transition:opacity .12s ease}
  .ss-item{animation:none;opacity:1}
}
.ss-item:hover,.ss-item.active{background:var(--primary-l)}
.ss-thumb{width:58px;height:34px;border-radius:7px;object-fit:cover;flex-shrink:0;background:var(--border)}
.ss-ico{width:40px;height:40px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:var(--bg);color:var(--primary);font-size:1.05rem}
.ss-body{min-width:0;flex:1;display:flex;flex-direction:column;gap:3px}
.ss-label{font-size:.86rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.ss-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
/* the eye-catching code badge */
.ss-code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.72rem;font-weight:800;
  background:linear-gradient(135deg,var(--primary),var(--green));color:#fff;
  padding:2px 8px;border-radius:6px;letter-spacing:.5px;direction:ltr;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.ss-type{font-size:.68rem;font-weight:700;color:var(--text-3);background:var(--bg);
  padding:2px 7px;border-radius:6px}
.ss-go{margin-right:auto;color:var(--text-3);font-size:.9rem;opacity:0;transition:opacity .12s;flex-shrink:0}
.ss-item:hover .ss-go,.ss-item.active .ss-go{opacity:1;color:var(--primary)}
.ss-empty{padding:18px;text-align:center;color:var(--text-3);font-size:.82rem}

/* responsive: tighter on phones, hide thumbs to keep it clean */
@media(max-width:575.98px){
  .search-suggest{padding:4px}
  .ss-item{padding:8px;gap:9px}
  .ss-thumb{width:46px;height:28px}
  .ss-ico{width:34px;height:34px}
  .ss-label{font-size:.82rem;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
}

.nav-links{display:flex;align-items:center;gap:2px;flex-shrink:0}
.nav-link{color:var(--text-2);font-size:.88rem;font-weight:600;padding:7px 14px;border-radius:var(--r);transition:all .15s;white-space:nowrap}
.nav-link:hover{color:var(--primary);background:var(--primary-l)}
.nav-link.on{color:var(--primary);background:var(--primary-l);font-weight:700}

.nav-auth{display:flex;gap:8px;flex-shrink:0;align-items:center}

/* ── SOCIAL BAR ─────────────────────────────── */
.social-bar{background:#fff;border-bottom:1px solid var(--border);padding:8px 0;overflow-x:auto}
.social-bar::-webkit-scrollbar{height:0}
.social-bar-inner{display:flex;gap:8px;align-items:center;min-width:max-content}

.soc-pill{display:inline-flex;align-items:center;gap:9px;padding:7px 16px;border-radius:var(--r-pill);
  border:1.5px solid var(--border);background:#fff;font-size:.78rem;font-weight:600;color:var(--text);
  cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap;box-shadow:var(--shadow-sm)}
.soc-pill:hover{transform:translateY(-2px);box-shadow:var(--shadow);color:var(--text)}
.soc-pill .si{font-size:.95rem}
.soc-pill .sn{font-size:.7rem;color:var(--text-3);font-weight:400;line-height:1}
.soc-pill .sc{font-weight:800;font-size:.85rem;line-height:1.2}
.soc-pill .wrap{display:flex;flex-direction:column}

.soc-pill.yt{border-color:rgba(255,0,0,.25)}.soc-pill.yt:hover{border-color:#FF0000;box-shadow:0 4px 16px rgba(255,0,0,.12)}.soc-pill.yt .si{color:#FF0000}
.soc-pill.ig{border-color:rgba(225,48,108,.25)}.soc-pill.ig:hover{border-color:#E1306C;box-shadow:0 4px 16px rgba(225,48,108,.1)}.soc-pill.ig .si{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#bc1888);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.soc-pill.tk{border-color:rgba(0,0,0,.15)}.soc-pill.tk:hover{border-color:#000;box-shadow:0 4px 16px rgba(0,0,0,.08)}.soc-pill.tk .si{color:#000}
.soc-pill.tg{border-color:rgba(0,136,204,.25)}.soc-pill.tg:hover{border-color:#0088CC;box-shadow:0 4px 16px rgba(0,136,204,.12)}.soc-pill.tg .si{color:#0088CC}

.soc-live-tag{font-size:.7rem;color:var(--text-3);margin-right:auto;display:flex;align-items:center;gap:4px;white-space:nowrap}
.dot-live{width:6px;height:6px;background:var(--green);border-radius:50%;animation:lp 2s infinite}

.shimmer .sc{display:inline-block;width:36px;height:12px;border-radius:3px;background:linear-gradient(90deg,var(--border) 25%,var(--bg) 50%,var(--border) 75%);background-size:200%;animation:sh 1.4s infinite}
@keyframes sh{0%{background-position:200%}100%{background-position:-200%}}

/* ── SEARCH / HERO ──────────────────────────── */
.search-hero{background:#fff;border-bottom:1px solid var(--border);padding:48px 0 36px;position:relative;overflow:hidden}
.search-hero::before{content:'';position:absolute;top:-60px;left:-60px;width:300px;height:300px;background:radial-gradient(circle,var(--primary-l) 0%,transparent 70%);pointer-events:none}
.search-hero::after{content:'';position:absolute;bottom:-40px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,var(--green-l) 0%,transparent 70%);pointer-events:none}
.search-hero h1{font-size:clamp(1.7rem,4vw,2.5rem);font-weight:900;color:var(--text);margin-bottom:8px;position:relative}
.search-hero .sub{font-size:.9rem;color:var(--text-2);margin-bottom:24px}

.big-search{display:flex;background:#fff;border:2px solid var(--border);border-radius:var(--r-xl);overflow:hidden;max-width:680px;box-shadow:var(--shadow);transition:border-color .3s ease,box-shadow .3s ease,border-radius .3s ease}
.big-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-l),var(--shadow)}
.big-search input{flex:1;background:transparent;border:none;outline:none;padding:14px 20px;color:var(--text);font-family:inherit;font-size:1rem}
.big-search input::placeholder{color:var(--text-3)}
.big-search button{background:var(--primary);border:none;padding:14px 26px;color:#fff;font-family:inherit;font-weight:700;font-size:.95rem;cursor:pointer;transition:background .15s;display:flex;align-items:center;gap:8px}
.big-search button:hover{background:var(--primary-d)}

.search-tabs{display:flex;gap:6px;margin-top:20px;flex-wrap:wrap}
.s-tab{padding:8px 18px;border-radius:var(--r-pill);background:#fff;border:1.5px solid var(--border);color:var(--text-2);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;box-shadow:var(--shadow-sm)}
.s-tab:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-l)}
.s-tab.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.25)}
.s-tab .cnt{background:rgba(255,255,255,.3);color:#fff;font-size:.7rem;padding:1px 8px;border-radius:50px;font-weight:700}
.s-tab:not(.active) .cnt{background:var(--border);color:var(--text-3)}

/* ── HOMEPAGE HERO ──────────────────────────── */
.home-hero{
  background:linear-gradient(135deg,#1E3A8A 0%,#1D4ED8 35%,#2563EB 60%,#059669 100%);
  padding:72px 0 60px;position:relative;overflow:hidden;
}
.home-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}
.home-hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:60px;background:var(--bg);clip-path:ellipse(55% 100% at 50% 100%)}
.home-hero .container{position:relative;z-index:1}

/* ── SECTIONS ───────────────────────────────── */
.sec{padding:40px 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.sec-title{font-size:1.15rem;font-weight:900;color:var(--text);display:flex;align-items:center;gap:10px}
.sec-title .dot{width:5px;height:22px;border-radius:3px;flex-shrink:0}
.dot-teal  {background:var(--primary)}
.dot-green {background:var(--green)}
.dot-red   {background:var(--red)}

.see-all{font-size:.78rem;color:var(--primary);font-weight:700;border:1.5px solid var(--primary-m);background:var(--primary-l);padding:6px 16px;border-radius:var(--r-pill);transition:all .2s;display:inline-flex;align-items:center;gap:5px}
.see-all:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── CONTENT CARD ───────────────────────────── */
.c-card{
  background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;
  transition:all .22s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;
  text-decoration:none;color:var(--text);height:100%;box-shadow:var(--shadow-sm);
}
.c-card:hover{border-color:var(--primary-m);transform:translateY(-4px);box-shadow:var(--shadow-lg),0 0 0 3px var(--primary-l);color:var(--text)}

.c-card-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:#F1F5F9}
.c-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.c-card:hover .c-card-thumb img{transform:scale(1.04)}

.c-card-empty-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#EFF6FF,#F0FDF4);display:flex;align-items:center;justify-content:center;font-size:2.5rem}

.type-badge{position:absolute;top:8px;right:8px;padding:3px 10px;border-radius:var(--r-pill);font-size:.68rem;font-weight:800;letter-spacing:.4px;text-transform:uppercase}
.tb-mod         {background:var(--primary);color:#fff}
.tb-resourcepack{background:var(--green);color:#fff}
.tb-shader      {background:var(--purple);color:#fff}
.tb-map         {background:var(--gold);color:#fff}
.tb-other       {background:var(--text-2);color:#fff}

.dur-tag{position:absolute;bottom:8px;left:8px;background:rgba(0,0,0,.7);color:#fff;font-size:.72rem;font-weight:700;padding:3px 8px;border-radius:6px;font-family:'Vazirmatn',monospace;backdrop-filter:blur(4px)}

.play-overlay{position:absolute;inset:0;background:rgba(37,99,235,.15);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.play-overlay i{font-size:3rem;color:#fff;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));transform:scale(.9);transition:transform .2s}
.c-card:hover .play-overlay{opacity:1}
.c-card:hover .play-overlay i{transform:scale(1)}

.c-card-body{padding:14px 16px;flex:1;display:flex;flex-direction:column;gap:6px}
.c-card-title{font-size:.93rem;font-weight:700;color:var(--text);line-height:1.35}
.c-card-desc{font-size:.8rem;color:var(--text-2);line-height:1.55;flex:1}

.c-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px}
.c-tag{font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:var(--r-pill)}
.ct-green {background:var(--green-l);color:var(--green);border:1px solid var(--green-m)}
.ct-teal  {background:var(--primary-l);color:var(--primary);border:1px solid var(--primary-m)}
.ct-gray  {background:#F1F5F9;color:#64748B;border:1px solid #E2E8F0}
.ct-red   {background:var(--red-l);color:var(--red);border:1px solid var(--red-m)}
.ct-purple{background:var(--purple-l);color:var(--purple);border:1px solid #DDD6FE}

.c-card-foot{padding:10px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:12px;font-size:.75rem;color:var(--text-3)}

/* ── MOD DETAIL ─────────────────────────────── */
.mod-hero{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);overflow:hidden;margin-bottom:24px;display:flex;flex-wrap:wrap;align-items:stretch}
.mod-hero-img{flex-shrink:0;align-self:stretch;border-left:1.5px solid var(--border);overflow:hidden;min-width:200px}
.mod-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.mod-hero-info{flex:1;min-width:0;padding:28px;display:flex;flex-direction:column;gap:14px}
.mod-hero-title{font-size:1.5rem;font-weight:900;color:var(--text);margin:0;line-height:1.3}
.mod-badges{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.mod-badge{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;padding:5px 12px;border-radius:var(--r-pill);border:1px solid}
.mod-badge.mc {background:var(--green-l);color:var(--green);border-color:var(--green-m)}
.mod-badge.ver{background:var(--primary-l);color:var(--primary);border-color:var(--primary-m)}
.mod-badge.dl {background:var(--bg);color:var(--text-2);border-color:var(--border)}
.mod-badge.date{background:var(--bg);color:var(--text-3);border-color:var(--border)}
.mod-desc-short{color:var(--text-2);font-size:.88rem;line-height:1.8;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.mod-dl-box{background:linear-gradient(135deg,var(--primary-l),var(--green-l));border:1.5px solid var(--primary-m);border-radius:var(--r-lg);padding:16px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:auto}
.mod-dl-box-info{flex:1;min-width:0}
.mod-dl-box-info .lbl{font-size:.75rem;color:var(--text-3);font-weight:600;margin-bottom:2px}
.mod-dl-box-info .name{font-size:.88rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mod-dl-box-info .size{font-size:.72rem;color:var(--text-3);margin-top:2px}
.mod-dl-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--primary),var(--primary-d));color:#fff;font-weight:800;font-size:.92rem;padding:11px 22px;border-radius:var(--r-pill);text-decoration:none;box-shadow:0 4px 16px rgba(37,99,235,.3);transition:transform .2s,box-shadow .2s;white-space:nowrap;flex-shrink:0}
.mod-dl-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,.4);color:#fff}
.mod-section{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:20px}
.mod-section-head{padding:16px 20px;border-bottom:1px solid var(--border);font-weight:800;font-size:.92rem;display:flex;align-items:center;gap:8px;color:var(--text)}
.mod-section-body{padding:20px;color:var(--text-2);line-height:1.9;font-size:.9rem}
.mod-file-row{display:flex;align-items:center;gap:14px;padding:14px 20px;border-top:1px solid var(--border)}
.mod-file-icon{width:40px;height:40px;background:var(--gold-l);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold);font-size:1.1rem}
.mod-file-btn{display:inline-flex;align-items:center;gap:6px;background:var(--primary);color:#fff;font-size:.8rem;font-weight:700;padding:7px 16px;border-radius:var(--r-pill);text-decoration:none;flex-shrink:0;transition:background .15s}
.mod-file-btn:hover{background:var(--primary-d);color:#fff}
.mod-others{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);overflow:hidden}
.mod-others-head{padding:14px 18px;border-bottom:1px solid var(--border);font-weight:800;font-size:.88rem;display:flex;align-items:center;gap:8px}
.mod-other-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid var(--border);text-decoration:none;color:var(--text);transition:background .12s}
.mod-other-row:hover{background:var(--primary-l)}
.mod-other-img{width:44px;height:44px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}
.mod-other-placeholder{width:44px;height:44px;background:var(--bg);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--border);color:var(--text-3)}
@media(max-width:600px){
  .mod-hero-img{width:100%;aspect-ratio:1/1;border-left:none;border-bottom:1.5px solid var(--border)}
  .mod-hero-img img{width:100%;height:100%}
  .mod-hero-info{padding:20px}
}

/* ── SIDEBAR FILTERS ────────────────────────── */
.filter-panel{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;position:sticky;top:80px;box-shadow:var(--shadow-sm)}
.filter-head{padding:12px 16px;border-bottom:1px solid var(--border);font-size:.75rem;font-weight:800;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;background:var(--bg)}
.filter-list{padding:6px}
.filter-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r);cursor:pointer;font-size:.85rem;color:var(--text-2);transition:all .15s;text-decoration:none}
.filter-item:hover{background:var(--primary-l);color:var(--primary)}
.filter-item.active{background:var(--primary-l);color:var(--primary);font-weight:700}
.filter-item .fi-count{margin-right:auto;font-size:.7rem;background:var(--border);color:var(--text-3);padding:1px 8px;border-radius:50px;font-weight:700}

/* ── COMMENTS ───────────────────────────────── */
.comment-box{display:flex;gap:12px;margin-bottom:14px}
.cmt-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--primary),var(--green));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.85rem;overflow:hidden}
.cmt-avatar img{width:100%;height:100%;object-fit:cover}
.cmt-body{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);padding:12px 16px;flex:1;box-shadow:var(--shadow-sm)}
.cmt-header{display:flex;gap:10px;align-items:baseline;margin-bottom:5px}
.cmt-name{font-weight:700;font-size:.83rem;color:var(--primary)}
.cmt-date{font-size:.73rem;color:var(--text-3)}
.cmt-text{font-size:.86rem;line-height:1.65}

/* ── FORUM ──────────────────────────────────── */
.f-cat{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;margin-bottom:10px;transition:all .2s;box-shadow:var(--shadow-sm)}
.f-cat:hover{border-color:var(--primary-m);box-shadow:var(--shadow)}
.f-cat-head{padding:16px 18px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}
.f-cat-icon{font-size:1.5rem}
.f-cat-name{font-weight:800;font-size:.95rem;color:var(--text)}
.f-cat-desc{font-size:.78rem;color:var(--text-2)}
.f-cat-foot{padding:10px 18px;display:flex;gap:16px;font-size:.76rem;color:var(--text-3);background:var(--bg)}

.f-thread{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#fff;border:1.5px solid var(--border);border-radius:var(--r);margin-bottom:6px;transition:all .2s;text-decoration:none;color:var(--text);box-shadow:var(--shadow-sm)}
.f-thread:hover{border-color:var(--primary-m);background:var(--primary-l);color:var(--text);transform:translateX(-2px)}
.f-av{width:38px;height:38px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--primary),var(--green));display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:.88rem;overflow:hidden}
.f-av img{width:100%;height:100%;object-fit:cover}
.f-thread-title{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:3px}
.f-thread-meta{font-size:.75rem;color:var(--text-3)}

.f-post{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.f-post-head{padding:12px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;background:var(--bg)}
.f-post-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--green));display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0}
.f-post-body{padding:18px;line-height:1.85;font-size:.9rem}

/* ── ADMIN ──────────────────────────────────── */
.stat-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);padding:20px 16px;text-align:center;transition:all .2s;cursor:pointer;display:block;color:var(--text);text-decoration:none;box-shadow:var(--shadow-sm)}
.stat-card:hover{border-color:var(--primary-m);transform:translateY(-3px);box-shadow:var(--shadow),0 0 0 3px var(--primary-l);color:var(--text)}
.stat-num{font-size:2rem;font-weight:900;color:var(--primary);line-height:1}
.stat-lbl{font-size:.76rem;color:var(--text-3);margin-top:6px}

/* ── AUTH ───────────────────────────────────── */
.auth-wrap{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:40px 16px}
.auth-card{width:100%;max-width:420px;background:#fff;border:1.5px solid var(--border);border-radius:var(--r-xl);padding:36px 32px;box-shadow:var(--shadow-xl)}
.auth-title{font-size:1.4rem;font-weight:900;color:var(--text);margin-bottom:6px}
.auth-sub{font-size:.82rem;color:var(--text-2)}

/* ── FORMS ──────────────────────────────────── */
.form-label{font-size:.82rem;font-weight:700;color:var(--text-2);margin-bottom:5px;display:block}
.form-control,.form-select{background:#fff!important;border:1.5px solid var(--border)!important;color:var(--text)!important;border-radius:var(--r)!important;font-family:inherit;font-size:.88rem}
.form-control:focus,.form-select:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px var(--primary-l)!important;background:#fff!important}
.form-control::placeholder{color:var(--text-3)!important}

/* ── BUTTONS ────────────────────────────────── */
.btn{font-family:inherit;border-radius:var(--r);font-weight:700;transition:all .2s}
.btn-primary{background:var(--primary)!important;border-color:var(--primary)!important;color:#fff!important;box-shadow:0 4px 12px rgba(37,99,235,.2)}
.btn-primary:hover{background:var(--primary-d)!important;border-color:var(--primary-d)!important;transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,.3)!important;color:#fff!important}
.btn-success{background:var(--green)!important;border-color:var(--green)!important;color:#fff!important}
.btn-success:hover{background:var(--green-d)!important;transform:translateY(-1px);color:#fff!important}
.btn-outline-primary{border:1.5px solid var(--primary)!important;color:var(--primary)!important;background:transparent!important}
.btn-outline-primary:hover{background:var(--primary)!important;color:#fff!important}
.btn-outline-success{border:1.5px solid var(--green)!important;color:var(--green)!important;background:transparent!important}
.btn-outline-success:hover{background:var(--green)!important;color:#fff!important}
.btn-outline-secondary{border:1.5px solid var(--border-h)!important;color:var(--text-2)!important;background:#fff!important}
.btn-outline-secondary:hover{background:var(--bg)!important;color:var(--text)!important}
.btn-outline-danger{border:1.5px solid var(--red-m)!important;color:var(--red)!important;background:transparent!important}
.btn-outline-danger:hover{background:var(--red)!important;color:#fff!important}
.btn-danger{background:var(--red)!important;border-color:var(--red)!important;color:#fff!important}
.btn-xs{font-size:.72rem;padding:.2rem .55rem}

/* ── BADGES ─────────────────────────────────── */
.badge{font-family:inherit}
.bg-success{background:var(--green-l)!important;color:var(--green)!important;border:1px solid var(--green-m)!important}
.bg-secondary{background:var(--bg)!important;color:var(--text-2)!important;border:1px solid var(--border)!important}
.bg-danger{background:var(--red-l)!important;color:var(--red)!important;border:1px solid var(--red-m)!important}

/* ── TABLES ─────────────────────────────────── */
.table{color:var(--text)}
.table-dark{--bs-table-bg:#fff;color:var(--text)!important}
.table-dark th{background:var(--bg)!important;color:var(--text-2)!important;border-color:var(--border)!important;font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.table-dark td{border-color:var(--border)!important;font-size:.85rem}
.table-hover>tbody>tr:hover>*{background:var(--primary-l)!important}

/* ── PAGINATION ─────────────────────────────── */
.page-link{background:#fff!important;border-color:var(--border)!important;color:var(--text-2)!important;font-family:inherit}
.page-link:hover{background:var(--primary-l)!important;color:var(--primary)!important;border-color:var(--primary-m)!important}
.page-item.active .page-link{background:var(--primary)!important;border-color:var(--primary)!important;color:#fff!important;font-weight:700}

/* ── LIST GROUPS ────────────────────────────── */
.list-group-item{background:#fff!important;border-color:var(--border)!important;color:var(--text)!important}
.list-group-item-action:hover{background:var(--primary-l)!important}

/* ── BREADCRUMB ─────────────────────────────── */
.breadcrumb{background:transparent}
.breadcrumb-item+.breadcrumb-item::before{color:var(--text-3)}
.breadcrumb-item a{color:var(--primary)}
.breadcrumb-item.active{color:var(--text-2)}

/* ── ALERTS ─────────────────────────────────── */
.alert-danger {background:var(--red-l);border-color:var(--red-m);color:#991B1B}
.alert-success{background:var(--green-l);border-color:var(--green-m);color:#166534}
.alert-info   {background:var(--primary-l);border-color:var(--primary-m);color:#1E40AF}
.alert-warning{background:var(--gold-l);border-color:#FDE68A;color:#92400E}
.alert-dark   {background:var(--bg);border-color:var(--border);color:var(--text-2)}

/* ── MODAL ──────────────────────────────────── */
.modal-content{background:#fff!important;border:1.5px solid var(--border)!important;border-radius:var(--r-xl)!important;box-shadow:var(--shadow-xl)!important}
.modal-header,.modal-footer{border-color:var(--border)!important;background:var(--bg)!important}

/* ── FOOTER ─────────────────────────────────── */
.site-footer{background:#fff;border-top:1px solid var(--border);padding:52px 0 28px;margin-top:60px;position:relative}
.site-footer::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:80px;height:3px;background:linear-gradient(90deg,var(--primary),var(--green));border-radius:3px}
.footer-brand{font-size:1.25rem;font-weight:900;background:linear-gradient(135deg,var(--primary),var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.footer-desc{font-size:.82rem;color:var(--text-2);margin-top:8px;line-height:1.7}
.footer-soc-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r);font-size:.78rem;font-weight:600;border:1.5px solid var(--border);background:#fff;color:var(--text-2);text-decoration:none;transition:all .2s;margin:3px;box-shadow:var(--shadow-sm)}
.footer-soc-btn:hover{border-color:var(--primary-m);color:var(--primary);background:var(--primary-l)}
.footer-head{font-size:.73rem;font-weight:800;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.footer-link{display:block;font-size:.84rem;color:var(--text-2);text-decoration:none;padding:4px 0;transition:color .15s}
.footer-link:hover{color:var(--primary)}
.footer-link i{margin-left:5px;font-size:.78rem}
.footer-divider{border-color:var(--border);margin:28px 0 18px}
.footer-copy{text-align:center;font-size:.78rem;color:var(--text-3)}
.footer-copy a{color:var(--primary)}

/* ── SCROLLBAR ──────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border-h);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--primary-m)}

/* ── GLASS CARD (alias) ─────────────────────── */
.glass-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.glass-card .card-head{padding:12px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:.85rem;color:var(--text-2);background:var(--bg)}

/* ── SIDEBAR BLOCK ──────────────────────────── */
.sidebar-block{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.sidebar-head{padding:11px 14px;border-bottom:1px solid var(--border);font-size:.75rem;font-weight:800;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;background:var(--bg)}

/* ── USER PROFILE ───────────────────────────── */
.profile-cover{height:200px;background:linear-gradient(135deg,var(--primary),var(--green));position:relative;border-radius:var(--r-xl) var(--r-xl) 0 0;overflow:hidden}
.profile-cover img{width:100%;height:100%;object-fit:cover}
.profile-avatar{width:96px;height:96px;border-radius:50%;border:4px solid #fff;box-shadow:var(--shadow);overflow:hidden;background:linear-gradient(135deg,var(--primary),var(--green));display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:900;color:#fff}
.profile-avatar img{width:100%;height:100%;object-fit:cover}
.profile-stat{text-align:center}
.profile-stat-num{font-size:1.3rem;font-weight:900;color:var(--text)}
.profile-stat-lbl{font-size:.73rem;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* ── USER POST CARD ─────────────────────────── */
.upost-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);padding:18px;margin-bottom:14px;box-shadow:var(--shadow-sm);transition:box-shadow .2s}
.upost-card:hover{box-shadow:var(--shadow)}
.upost-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.upost-content{font-size:.93rem;line-height:1.75;color:var(--text);margin-bottom:12px}
.upost-img{border-radius:var(--r);overflow:hidden;margin-bottom:12px;max-height:400px}
.upost-img img{width:100%;height:100%;object-fit:cover}
.upost-actions{display:flex;gap:16px;padding-top:12px;border-top:1px solid var(--border)}
.upost-btn{display:inline-flex;align-items:center;gap:6px;font-size:.83rem;color:var(--text-2);background:none;border:none;cursor:pointer;font-family:inherit;font-weight:600;padding:6px 10px;border-radius:var(--r);transition:all .15s}
.upost-btn:hover{background:var(--primary-l);color:var(--primary)}
.upost-btn.liked{color:var(--red)}
.upost-btn.liked:hover{background:var(--red-l)}

/* ── DM CHAT ────────────────────────────────── */
.chat-bubble{max-width:72%;padding:10px 14px;border-radius:18px;font-size:.88rem;line-height:1.6;margin-bottom:6px}
.chat-bubble.sent{background:var(--primary);color:#fff;border-bottom-left-radius:4px;margin-right:auto}
.chat-bubble.recv{background:#fff;color:var(--text);border:1.5px solid var(--border);border-bottom-right-radius:4px;margin-left:auto}
.chat-time{font-size:.68rem;color:var(--text-3);margin-top:2px}

/* ── PAGE TITLE ACCENT ──────────────────────── */
.page-title{font-size:1.5rem;font-weight:900;color:var(--text);padding-bottom:14px;margin-bottom:20px;border-bottom:2px solid var(--border);position:relative}
.page-title::after{content:'';position:absolute;bottom:-2px;right:0;width:60px;height:2px;background:var(--primary);border-radius:2px}

/* ── DASHBOARD TABS ─────────────────────────── */
.dash-tab{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--r);color:var(--text-2);font-weight:600;font-size:.88rem;text-decoration:none;transition:all .15s;border:1.5px solid transparent}
.dash-tab:hover{background:var(--primary-l);color:var(--primary)}
.dash-tab.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.25)}
.dash-tab i{font-size:1rem}

/* ── NOTIFICATION BADGE ─────────────────────── */
.notif-badge{background:var(--red);color:#fff;font-size:.65rem;font-weight:800;padding:1px 6px;border-radius:50px;min-width:18px;text-align:center}

/* ── AUTO-RESIZE TEXTAREA ───────────────────── */
textarea.auto-grow{resize:none;overflow:hidden;min-height:80px;transition:height .1s}
textarea{resize:none}

/* ── MOD CARD SQUARE THUMBNAIL ──────────────── */
.c-card.mod-card .c-card-thumb{aspect-ratio:1/1}
.c-card.mod-card .c-card-empty-thumb{aspect-ratio:1/1}
.c-card-thumb{aspect-ratio:16/9}

/* ── COMMUNITY POST IMAGE RESPONSIVE ────────── */
.community-post-img{width:auto;max-width:100%;height:auto;border-radius:var(--r);display:block}

/* ── DROPDOWN MENU ───────────────────────────── */
.dropdown-menu{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:6px}
.dropdown-item{color:var(--text);font-size:.85rem;border-radius:var(--r);padding:8px 14px;font-weight:500}
.dropdown-item:hover{background:var(--primary-l);color:var(--primary)}
.dropdown-item.text-success{color:var(--green)!important}
.dropdown-item.text-danger{color:var(--red)!important}
.dropdown-divider{border-color:var(--border)}

/* ── HAMBURGER BUTTON ────────────────────────── */
.hamburger-btn{
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  gap:5px;background:none;border:1.5px solid var(--border);padding:8px 10px;
  border-radius:var(--r);cursor:pointer;width:40px;height:40px;flex-shrink:0;
  transition:all .2s;
}
.hamburger-btn span{display:block;width:18px;height:2px;background:var(--text-2);border-radius:2px;transition:all .25s}
.hamburger-btn:hover{border-color:var(--primary);background:var(--primary-l)}
.hamburger-btn:hover span{background:var(--primary)}
.hamburger-btn.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger-btn.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger-btn.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE MENU ─────────────────────────────── */
.mobile-menu{
  display:none;background:#fff;border-top:1px solid var(--border);
  padding:12px 0 16px;box-shadow:0 8px 24px rgba(0,0,0,.08);
}
.mobile-menu.open{display:block}
.mobile-nav-links{display:flex;flex-direction:column;gap:2px}
.mobile-nav-link{
  display:flex;align-items:center;gap:10px;padding:11px 8px;
  border-radius:var(--r);color:var(--text-2);font-size:.9rem;font-weight:600;
  text-decoration:none;transition:all .15s;
}
.mobile-nav-link:hover{background:var(--primary-l);color:var(--primary)}
.mobile-nav-link i{font-size:1rem;width:20px;text-align:center}

/* ── RESPONSIVE HEADER ───────────────────────── */
.nav-links{display:flex}
@media(max-width:1024px){
  .nav-links{gap:0}
  .nav-link{padding:6px 10px;font-size:.82rem}
}
@media(max-width:991px){
  .nav-links{display:none}
  .nav-inner{flex-wrap:nowrap;gap:8px;padding:10px 0}
  /* Keep search visible on mobile but compact */
  #nav-search-form .search-text{display:none}
}
@media(max-width:600px){
  #nav-search-form{flex:1;max-width:none;min-width:0}
  #nav-search-form input{min-width:0;font-size:.82rem;padding:7px 10px}
  #nav-search-form button{padding:7px 10px}
}
@media(min-width:992px){
  .hamburger-btn{display:none!important}
  .mobile-menu{display:none!important}
}
@media(max-width:768px){
  .nav-inner{gap:8px;padding:8px 0}
  .social-bar{padding:6px 0}
  .filter-panel{position:static}
  .home-hero{padding:36px 0 28px}
  .sec{padding:24px 0}
  .profile-cover{height:140px}
  .brand-txt{font-size:.95rem}
}
@media(max-width:640px){
  .brand-img{width:30px;height:30px}
  .auth-card{padding:24px 18px}
  .home-hero h1{font-size:1.6rem!important}
  .home-hero::after{display:none}
}
@media(max-width:480px){
  .soc-pill .wrap{display:none}
  .nav-auth{gap:6px}
}

/* ── IMAGE CROP PREVIEW ──────────────────────── */
.img-crop-wrap{position:relative;overflow:hidden;border-radius:var(--r);background:#F1F5F9;border:2px dashed var(--border);cursor:pointer;transition:border-color .2s}
.img-crop-wrap:hover{border-color:var(--primary)}
.img-crop-preview{width:100%;display:block;object-fit:cover}

/* ── SQUARE THUMB (mod uploads) ──────────────── */
.sq-thumb{aspect-ratio:1/1;object-fit:cover;border-radius:var(--r)}

/* ── RESPONSIVE CARDS ────────────────────────── */
@media(max-width:576px){
  .c-card-body{padding:10px 12px}
  .c-card-foot{padding:8px 12px}
  .c-card-title{font-size:.85rem}
}

/* ── ENGAGEMENT SECTION ──────────────────────── */
.engage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.engage-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);transition:all .2s;text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:10px}
.engage-card:hover{border-color:var(--primary-m);transform:translateY(-3px);box-shadow:var(--shadow);color:var(--text)}
.engage-card-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.engage-card-num{font-size:1.6rem;font-weight:900;color:var(--text);line-height:1}
.engage-card-lbl{font-size:.78rem;color:var(--text-3);font-weight:600}

/* ── LEADERBOARD ─────────────────────────────── */
.leader-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--r);transition:background .15s}
.leader-row:hover{background:var(--primary-l)}
.leader-rank{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;flex-shrink:0}

/* ── FORUM COMPACT ───────────────────────────── */
.forum-compact-list{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.forum-compact-item{display:flex;align-items:center;gap:10px;padding:11px 14px;transition:background .15s;text-decoration:none;color:var(--text)}
.forum-compact-item+.forum-compact-item{border-top:1px solid var(--border)}
.forum-compact-item:hover{background:var(--primary-l);color:var(--text)}
.forum-compact-item .fci-title{font-size:.85rem;font-weight:600;flex:1;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.forum-compact-item .fci-meta{font-size:.72rem;color:var(--text-3);white-space:nowrap}

/* ── CROPPER MODAL ───────────────────────────── */
.crop-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}
.crop-modal-box{background:#fff;border-radius:var(--r-xl);padding:24px;max-width:540px;width:100%;box-shadow:var(--shadow-xl)}
.crop-modal-box h3{font-size:1rem;font-weight:800;margin-bottom:16px}
.crop-canvas-wrap{border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:#F1F5F9;position:relative;max-height:380px;display:flex;align-items:center;justify-content:center}
.crop-canvas-wrap img{max-width:100%;max-height:380px;display:block}

/* ══════════════════════════════════════════════════
   MOBILE HARDENING — prevents overflow & shrinks oversized inline styles
   ══════════════════════════════════════════════════ */
/* Admin tables never cause horizontal page scroll */
.table-responsive,.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{max-width:100%}

@media(max-width:768px){
  /* Admin form containers that hardcode max-width should fill the screen */
  [style*="max-width:860px"],[style*="max-width:800px"],[style*="max-width:680px"]{max-width:100%!important}
  .big-search input{padding:11px 14px!important;font-size:.95rem}
  .mod-detail-img{max-height:280px}
}

@media(max-width:640px){
  /* Filter/search controls in admin: stack full-width instead of fixed px */
  .admin-controls{flex-wrap:wrap}
  .admin-controls input,.admin-controls select,
  input[type="search"][style*="width:"],select[style*="width:140px"],select[style*="width:180px"]{
    width:100%!important;min-width:0!important}
}

@media(max-width:576px){
  body{font-size:14px}
  .container,.container-fluid{padding-left:14px;padding-right:14px}
  /* Catch oversized fixed-pixel boxes so they never overflow the viewport */
  [style*="max-width:320px"],[style*="max-width:400px"]{max-width:100%!important}
  .auth-card{padding:20px 16px!important}
  .chat-bubble{max-width:88%!important}
  .ss-label{white-space:normal}
  /* Hero stats: wrap & shrink rather than overflow */
  .hero-stats{flex-wrap:wrap;gap:10px!important}
  .hero-stats > *{padding:8px 14px!important}
}

@media(max-width:480px){
  .dropdown-menu{min-width:160px!important}
  .profile-avatar{width:78px!important;height:78px!important}
}
