/* ══════════════════════════════════════
   MineAddons  main.css  v4.0
   Fix: nav drawer, overflow, no spinner
══════════════════════════════════════ */

/* ── TOKENS ── */
:root{
  --bg:     #0b0e14;
  --surf:   #131820;
  --surf2:  #1c2333;
  --brd:    rgba(255,255,255,.07);
  --green:  #22c55e;
  --greenl: #4ade80;
  --greend: #15803d;
  --greens: rgba(34,197,94,.08);
  --greeng: rgba(34,197,94,.15);
  --blue:   #3b82f6;
  --txt:    #f1f5f9;
  --txtm:   #64748b;
  --txtd:   #94a3b8;
  --wa:     #25D366;
  --r:      10px;
  --rl:     16px;
  --rxl:    20px;
  --sh:     0 4px 20px rgba(0,0,0,.4);
  --shl:    0 8px 32px rgba(0,0,0,.55);
  --shg:    0 4px 20px rgba(34,197,94,.2);
  --ease:   cubic-bezier(.4,0,.2,1);
  --t:      all .22s var(--ease);
  --font:   'Outfit', system-ui, sans-serif;
  --hh:     58px; /* header height */
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{
  scroll-behavior:smooth;
  overflow-x:clip; /* clip = no scrollbar but content hidden - better than hidden */
}
body{
  font-family:var(--font);font-size:16px;line-height:1.6;
  background:var(--bg);color:var(--txt);min-height:100vh;
  overflow-x:clip;
}
img{max-width:100%;display:block;}
::-webkit-scrollbar{width:5px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--surf2);border-radius:99px;}
::-webkit-scrollbar-thumb:hover{background:var(--greend);}

/* ── UTILS ── */
.hidden{display:none!important;}
.text-secondary,.text-muted{color:var(--txtm);}
.text-green{color:var(--green);}
.w-full{width:100%!important;}
.container{width:92%;max-width:1240px;margin:0 auto;}

/* ── FA ICON BRIDGE — JS generates <span class="icon icon-*"> ── */
.icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:1em;height:1em;vertical-align:middle;
  font-family:"Font Awesome 6 Free","Font Awesome 6 Brands";
  font-weight:900;font-style:normal;line-height:1;
  -webkit-font-smoothing:antialiased;
}
.icon-download::before{content:"\f019";}
.icon-like::before{content:"\f004";}
.icon-comment::before{content:"\f075";}
.icon-rating{font-weight:900;color:#fbbf24;}
.icon-rating::before{content:"\f005";}
.icon-user::before{content:"\f007";}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 20px;border:none;border-radius:var(--r);
  font-family:var(--font);font-size:.9rem;font-weight:600;
  text-decoration:none;cursor:pointer;transition:var(--t);
  white-space:nowrap;user-select:none;line-height:1.3;
}
.btn:active{transform:scale(.97)!important;}
.btn-primary{background:var(--green);color:#062010;}
.btn-primary:hover{background:var(--greenl);transform:translateY(-2px);box-shadow:var(--shg);}
.btn-secondary{background:var(--surf);color:var(--txt);border:1px solid var(--brd);}
.btn-secondary:hover{background:var(--surf2);border-color:rgba(34,197,94,.35);transform:translateY(-1px);}
.btn-wa{background:var(--wa);color:#fff;}
.btn-wa:hover{background:#1ebe5d;transform:translateY(-2px);box-shadow:0 4px 14px rgba(37,211,102,.28);}

/* ── FORMS ── */
.field{margin-bottom:1rem;}
.field>label,.form-group label{
  display:block;margin-bottom:5px;
  font-size:.8rem;font-weight:600;color:var(--txtd);letter-spacing:.01em;
}
.field>label small,.form-group label small{font-weight:400;color:var(--txtm);margin-left:5px;}
.field-wrap,.input-wrap{position:relative;}
.field-wrap>i,.input-wrap>i{
  position:absolute;left:11px;top:50%;transform:translateY(-50%);
  color:var(--txtm);font-size:.8rem;pointer-events:none;
}
.field-wrap .form-control,.input-wrap .form-control{padding-left:34px;}
.field-wrap:focus-within>i,.input-wrap:focus-within>i{color:var(--green);}
.form-control{
  width:100%;padding:10px 12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--brd);border-radius:var(--r);
  color:var(--txt);font-family:var(--font);font-size:.9rem;
  transition:border-color .2s,box-shadow .2s,background .2s;
  appearance:none;-webkit-appearance:none;
}
.form-control::placeholder{color:var(--txtm);}
.form-control:focus{
  outline:none;border-color:var(--green);
  background:rgba(34,197,94,.04);
  box-shadow:0 0 0 3px var(--greeng);
}
textarea.form-control{resize:vertical;min-height:100px;}
select.form-control{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2364748b'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 9px center;background-size:18px;
  padding-right:30px;cursor:pointer;
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;}
.drop-zone{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;
  border:2px dashed var(--brd);border-radius:var(--r);
  padding:1.6rem 1rem;text-align:center;cursor:pointer;
  transition:var(--t);background:rgba(255,255,255,.02);
  color:var(--txtm);position:relative;overflow:hidden;
}
.drop-zone:hover{border-color:var(--green);background:var(--greens);color:var(--txt);}
.drop-zone i{font-size:1.7rem;}
.drop-zone strong{color:var(--green);}
.drop-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}

/* ── STARS ── */
.star-rating{display:flex;gap:4px;margin-top:4px;}
.star-rating .star{cursor:pointer;font-size:1.4rem;color:rgba(255,255,255,.2);transition:color .15s,transform .12s;line-height:1;}
.star-rating .star:hover{transform:scale(1.15);}
.star-rating .star.active{color:#fbbf24;}
.star-rating.readonly .star{cursor:default;}

/* ══════════════════════════════════════
   HEADER
══════════════════════════════════════ */
header{
  position:sticky;top:0;z-index:200;
  background:rgba(11,14,20,.94);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--brd);
  width:100%;
}
.hdr-inner{
  width:92%;max-width:1240px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:var(--hh);
}
.logo{display:flex;align-items:center;gap:9px;text-decoration:none;flex-shrink:0;}
.logo-mark{
  width:32px;height:32px;
  background:linear-gradient(135deg,var(--green),var(--greenl));
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-family:monospace;font-weight:800;font-size:1rem;color:#062010;
  box-shadow:0 0 10px rgba(34,197,94,.3);flex-shrink:0;
}
.logo-text{font-size:1.2rem;font-weight:600;color:var(--txtd);}
.logo-text strong{color:var(--green);font-weight:800;}

/* ── BURGER ── */
.burger{
  display:none;flex-direction:column;justify-content:space-between;
  width:24px;height:17px;cursor:pointer;background:none;border:none;
  padding:0;z-index:201;flex-shrink:0;
}
.burger span{display:block;height:2px;width:100%;background:var(--txt);border-radius:99px;transition:var(--t);}
.burger.active span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.burger.active span:nth-child(2){opacity:0;transform:scaleX(0);}
.burger.active span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* ── NAV — Desktop: in normal flow. Mobile: fixed drawer ── */
nav#main-nav{
  /* Desktop */
  display:flex;align-items:center;gap:.1rem;
  /* Hide on mobile by default — shown via media query logic */
}
.nav-link{
  display:flex;align-items:center;gap:5px;
  color:var(--txtm);text-decoration:none;
  font-size:.84rem;font-weight:500;
  padding:6px 11px;border-radius:8px;
  transition:var(--t);white-space:nowrap;
}
.nav-link i{font-size:.76rem;flex-shrink:0;}
.nav-link:hover{color:var(--txt);background:rgba(255,255,255,.07);}
.nav-link.active{color:var(--green);background:var(--greens);}
.nav-cta{
  background:var(--green);color:#062010!important;
  font-weight:700;padding:6px 14px;
}
.nav-cta:hover{background:var(--greenl)!important;transform:translateY(-1px);box-shadow:var(--shg);}
.nav-verified{color:var(--blue)!important;border:1px solid rgba(59,130,246,.2);}
.nav-verified:hover{background:rgba(59,130,246,.08)!important;color:#60a5fa!important;}

/* ── OVERLAY — covers page when nav is open ── */
.nav-overlay{
  display:none;                /* hidden by default */
  position:fixed;
  inset:0;                     /* top:0 right:0 bottom:0 left:0 */
  background:rgba(0,0,0,.6);
  z-index:299;                 /* below nav (300) but above all content */
  backdrop-filter:blur(2px);
  cursor:pointer;
}
.nav-overlay.active{display:block;}

/* ══════════════════════════════════════
   PAGES
══════════════════════════════════════ */
.page{display:none;padding:1.75rem 0 4rem;animation:fadeUp .26s var(--ease) both;}
.page.active{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
.pg-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.4rem;flex-wrap:wrap;gap:.5rem;}
.pg-title{font-size:1.6rem;font-weight:800;display:inline-flex;align-items:center;gap:.45rem;letter-spacing:-.02em;}
.pg-title i{color:var(--green);}
.page-title{font-size:1.6rem;font-weight:800;margin-bottom:1.4rem;display:flex;align-items:center;gap:.45rem;}
.hot-badge{background:var(--greens);border:1px solid rgba(34,197,94,.18);color:var(--green);font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:99px;}

/* Spinner divs used by JS — keep them hidden always */
#home-loading-spinner,
#loading-indicator{display:none!important;}

/* ══════════════════════════════════════
   AUTH
══════════════════════════════════════ */
.auth-wrap{display:flex;justify-content:center;padding:2rem 0 4rem;}
.auth-card{
  width:100%;max-width:440px;
  background:var(--surf);border:1px solid var(--brd);
  border-radius:var(--rxl);padding:2.2rem;
  box-shadow:var(--shl);position:relative;overflow:hidden;
}
.auth-blob{
  position:absolute;top:-60px;right:-60px;
  width:180px;height:180px;
  background:radial-gradient(circle,rgba(34,197,94,.1) 0%,transparent 70%);
  pointer-events:none;
}
.auth-top{text-align:center;margin-bottom:1.5rem;}
.auth-ico{
  width:46px;height:46px;background:var(--greens);
  border:1px solid rgba(34,197,94,.18);border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto .8rem;font-size:1.2rem;color:var(--green);
}
.auth-top h2{font-size:1.45rem;letter-spacing:-.02em;margin-bottom:.2rem;}
.auth-top p{color:var(--txtm);font-size:.86rem;}
.auth-switch{text-align:center;margin-top:1.2rem;font-size:.84rem;color:var(--txtm);}
.auth-switch a{color:var(--green);text-decoration:none;font-weight:600;}
.auth-switch a:hover{text-decoration:underline;}
.divider{display:flex;align-items:center;gap:.8rem;margin:1rem 0;color:var(--txtm);font-size:.76rem;}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--brd);}
.auth-note{margin-top:.75rem;font-size:.75rem;color:var(--txtm);text-align:center;line-height:1.5;}
.auth-note i{color:var(--blue);margin-right:3px;}

/* ── COMMUNITY ── */
.community{
  margin-top:1.3rem;
  background:rgba(34,197,94,.05);
  border:1px solid rgba(34,197,94,.12);
  border-radius:14px;padding:1.1rem .9rem;
}
.comm-title{display:flex;align-items:center;gap:.4rem;font-weight:700;font-size:.88rem;margin-bottom:.35rem;}
.comm-title i{color:var(--green);}
.comm-sub{font-size:.78rem;color:var(--txtm);margin-bottom:.8rem;line-height:1.5;}
.comm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.45rem;}
.comm-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  padding:.5rem .3rem;border-radius:9px;text-decoration:none;
  font-size:.7rem;font-weight:600;transition:var(--t);
  border:1px solid var(--brd);background:rgba(255,255,255,.03);color:var(--txtd);
}
.comm-btn i{font-size:1.1rem;}
.comm-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.07);}
.c-wa i{color:#25D366;} .c-wa:hover{border-color:rgba(37,211,102,.3);}
.c-dc i{color:#7289da;} .c-dc:hover{border-color:rgba(114,137,218,.3);}
.c-ig i{color:#e1306c;} .c-ig:hover{border-color:rgba(225,48,108,.3);}
.c-yt i{color:#ff0000;} .c-yt:hover{border-color:rgba(255,0,0,.3);}
.c-tt i{color:#69c9d0;} .c-tt:hover{border-color:rgba(105,201,208,.3);}
.c-tg i{color:#0088cc;} .c-tg:hover{border-color:rgba(0,136,204,.3);}

/* ══════════════════════════════════════
   FILTER BAR
══════════════════════════════════════ */
.filter-bar{
  display:flex;flex-wrap:wrap;gap:.65rem;align-items:center;
  background:var(--surf);border:1px solid var(--brd);
  border-radius:var(--rl);padding:1rem;margin-bottom:1.5rem;
}
.search-wrap{flex:1;min-width:160px;position:relative;}
.search-wrap>i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--txtm);font-size:.8rem;pointer-events:none;}
.search-wrap .form-control{padding-left:32px;}
.f-select{width:auto;flex-shrink:0;}

/* ══════════════════════════════════════
   ADDON GRID & CARDS
══════════════════════════════════════ */
.addon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(256px,1fr));gap:1rem;}
.addon-card{
  background:var(--surf);border:1px solid var(--brd);
  border-radius:var(--rl);overflow:hidden;cursor:pointer;
  transition:transform .22s var(--ease),box-shadow .22s,border-color .22s;
  display:flex;flex-direction:column;
}
.addon-card:hover{transform:translateY(-5px);box-shadow:var(--shl),0 0 0 1px rgba(34,197,94,.28);border-color:rgba(34,197,94,.28);}
.addon-card.skeleton{pointer-events:none;}
.addon-card.skeleton:hover{transform:none;box-shadow:none;border-color:var(--brd);}
.card-thumbnail{
  width:100%;aspect-ratio:16/9;
  background:var(--surf2);background-size:cover;background-position:center;
  position:relative;overflow:hidden;
}
.card-thumbnail::after{
  content:'';position:absolute;bottom:0;left:0;width:100%;height:45%;
  background:linear-gradient(transparent,rgba(8,10,14,.8));pointer-events:none;
}
.no-image-placeholder{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:.8rem;color:var(--txtm);
}
.card-content{padding:.85rem 1rem 1rem;flex:1;display:flex;flex-direction:column;gap:.28rem;}
.card-title{font-size:.98rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card-creator{font-size:.78rem;color:var(--txtm);display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
.card-category{
  display:inline-flex;align-items:center;
  background:var(--greens);color:var(--green);
  border:1px solid rgba(34,197,94,.13);
  padding:2px 8px;border-radius:99px;
  font-size:.68rem;font-weight:700;letter-spacing:.02em;
  width:fit-content;
}
.card-stats{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.76rem;color:var(--txtm);
  margin-top:auto;padding-top:.6rem;border-top:1px solid var(--brd);
}
.card-stats span{display:flex;align-items:center;gap:3px;}
.card-stats .icon{font-size:.72rem;}

/* Verified badge */
.verified-badge{color:var(--blue);font-size:11px;margin-left:2px;vertical-align:middle;}
.verified-badge.small{font-size:11px;}
.verified-badge.medium{font-size:13px;}
.verified-badge.large{font-size:15px;}
.meta-creator,.comment-author{display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
.meta-creator a{display:inline-flex;align-items:center;gap:3px;}

/* ══════════════════════════════════════
   ADDON DETAIL
══════════════════════════════════════ */
.addon-detail-header{display:grid;grid-template-columns:1.6fr 1fr;gap:1.3rem;margin-bottom:1.5rem;}
.addon-gallery{background:var(--surf);border:1px solid var(--brd);border-radius:var(--rl);overflow:hidden;}
.gallery-main-image{width:100%;aspect-ratio:16/9;background:var(--surf2);background-size:cover;background-position:center;}
.gallery-thumbnails{display:flex;gap:7px;padding:10px;background:var(--bg);overflow-x:auto;}
.gallery-thumbnails::-webkit-scrollbar{height:3px;}
.gallery-thumb{
  width:68px;height:51px;min-width:68px;
  background-size:cover;background-position:center;
  border-radius:7px;border:2px solid transparent;
  cursor:pointer;transition:var(--t);opacity:.6;
}
.gallery-thumb:hover{opacity:1;}
.gallery-thumb.active{border-color:var(--green);opacity:1;}
.addon-meta{
  background:var(--surf);border:1px solid var(--brd);
  border-radius:var(--rl);padding:1.3rem;
  display:flex;flex-direction:column;gap:.8rem;
}
.addon-meta h1{font-size:1.6rem;line-height:1.2;letter-spacing:-.02em;}
.meta-creator{font-size:.86rem;color:var(--txtm);}
.meta-creator a{color:var(--greenl);text-decoration:none;font-weight:600;}
.meta-creator a:hover{text-decoration:underline;}
.meta-actions{display:flex;gap:.6rem;flex-wrap:wrap;}
.meta-stats{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;}
.meta-stats div{background:rgba(255,255,255,.02);padding:10px;border-radius:var(--r);border:1px solid var(--brd);}
.meta-stats strong{display:block;font-size:.98rem;font-weight:700;margin-top:2px;}
.addon-detail-content{display:flex;gap:1.3rem;}
.addon-description{flex:3;background:var(--surf);padding:1.3rem;border-radius:var(--rl);border:1px solid var(--brd);line-height:1.8;}
.addon-sidebar{flex:1;}
.rating-section{margin-top:1.1rem;padding-top:.9rem;border-top:1px solid var(--brd);}
.rating-section h4{margin-bottom:.4rem;font-size:.88rem;color:var(--txtd);}
#rating-status{font-size:.8rem;margin-top:4px;color:var(--green);}

/* ── COMMENTS ── */
.comment-section h3{margin-bottom:.9rem;font-size:1.1rem;font-weight:700;}
.comment-form textarea{min-height:90px;resize:vertical;}
.comment-form button{margin-top:.5rem;}
.comment-list{margin-top:1.1rem;display:flex;flex-direction:column;gap:.8rem;}
.comment{display:flex;gap:.85rem;background:var(--surf);padding:1rem;border-radius:var(--rl);border:1px solid var(--brd);}
.comment:hover{border-color:rgba(34,197,94,.2);}
.comment-avatar{width:34px;height:34px;min-width:34px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--greenl));display:flex;align-items:center;justify-content:center;color:#062010;font-weight:800;font-size:.82rem;}
.comment-body{flex:1;}
.comment-author{font-weight:700;color:var(--greenl);font-size:.83rem;}
.comment-date{font-size:.74rem;color:var(--txtm);margin-left:.4rem;}
.comment-text{margin-top:.28rem;font-size:.86rem;line-height:1.6;color:var(--txtd);}

/* ── UPLOAD ── */
.upload-box{max-width:760px;margin:0 auto;background:var(--surf);border:1px solid var(--brd);border-radius:var(--rxl);padding:2rem;}
.upload-container{}
.upload-progress{width:100%;height:5px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden;margin:.8rem 0 .3rem;}
.progress-bar{width:0%;height:100%;background:linear-gradient(90deg,var(--green),var(--greenl));transition:width .3s var(--ease);border-radius:99px;}

/* ── PROFILE ── */
.profile-box{background:var(--surf);border:1px solid var(--brd);border-radius:var(--rxl);padding:1.75rem;}
.profile-box p{display:flex;align-items:center;gap:.8rem;padding:.38rem 0;border-bottom:1px solid var(--brd);}
.profile-box p:last-of-type{border:none;}
.lbl{font-size:.72rem;font-weight:700;color:var(--txtm);text-transform:uppercase;letter-spacing:.06em;min-width:65px;}
.val{font-size:.9rem;color:var(--txt);font-weight:500;}
.sect-label{font-size:.95rem;font-weight:700;color:var(--txtd);margin:1.4rem 0 .9rem;display:flex;align-items:center;gap:.35rem;}
.sect-label i{color:var(--green);}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:20px;left:50%;
  transform:translateX(-50%) translateY(8px);
  padding:10px 20px;border-radius:var(--r);
  color:#fff;font-size:.86rem;font-weight:500;
  z-index:2000;opacity:0;visibility:hidden;
  transition:opacity .22s,transform .22s,visibility .22s;
  box-shadow:var(--shl);display:flex;align-items:center;gap:8px;
  white-space:nowrap;max-width:92vw;
}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.toast-error{background:linear-gradient(135deg,#991b1b,#ef4444);}
.toast-success{background:linear-gradient(135deg,var(--greend),var(--green));color:#062010;}

/* ── SPINNER (kept for JS compatibility but hidden) ── */
.spinner{
  width:30px;height:30px;
  border:3px solid rgba(255,255,255,.1);border-top-color:var(--green);
  border-radius:50%;animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── SKELETON ── */
.skeleton,.skeleton-thumbnail,.skeleton-line{
  background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;
}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
.skeleton-thumbnail{width:100%;aspect-ratio:16/9;border-radius:var(--r);}
.skeleton-line{height:12px;border-radius:3px;margin-bottom:7px;}
.skeleton-stats{display:flex;gap:8px;margin-top:8px;}
.skeleton-stats .skeleton-line{height:10px;width:48px;}
.addon-detail-skeleton{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;padding:1.1rem 0;}
.skeleton-gallery{display:flex;flex-direction:column;gap:.6rem;}
.skeleton-image{width:100%;aspect-ratio:16/9;background:rgba(255,255,255,.05);border-radius:var(--rl);}
.skeleton-thumbnails{display:flex;gap:.4rem;}
.skeleton-thumb{width:66px;height:50px;background:rgba(255,255,255,.05);border-radius:6px;}
.skeleton-meta{display:flex;flex-direction:column;gap:.85rem;}
.skeleton-title{width:70%;height:24px;background:rgba(255,255,255,.05);border-radius:5px;}
.skeleton-creator{width:40%;height:15px;background:rgba(255,255,255,.05);border-radius:3px;}
.skeleton-actions{display:flex;gap:.6rem;}
.skeleton-button{width:120px;height:38px;background:rgba(255,255,255,.05);border-radius:var(--r);}
.skeleton-stat{height:15px;background:rgba(255,255,255,.05);border-radius:3px;}
.error-state{padding:2rem;text-align:center;color:var(--txtm);background:var(--surf);border:1px solid var(--brd);border-radius:var(--rl);}
.error-state small{display:block;margin-top:.35rem;font-size:.78rem;}

/* ══════════════════════════════════════
   RESPONSIVE ≤ 900px — MOBILE NAV DRAWER
══════════════════════════════════════ */
@media(max-width:900px){
  .burger{display:flex;}

  /* Nav becomes fixed right-side drawer */
  nav#main-nav{
    position:fixed;
    top:0;
    right:-100%;           /* fully off screen */
    width:min(260px,78vw); /* never exceed viewport */
    height:100%;
    height:100dvh;
    background:var(--surf);
    border-left:1px solid var(--brd);
    flex-direction:column;
    justify-content:flex-start;
    align-items:stretch;
    padding-top:calc(var(--hh) + 8px);
    gap:0;
    box-shadow:-6px 0 24px rgba(0,0,0,.5);
    transition:right .26s var(--ease);
    z-index:300;            /* above overlay (299) */
    overflow-y:auto;
    overflow-x:hidden;
  }
  nav#main-nav.active{right:0;}

  .nav-link{
    width:100%;padding:12px 18px;
    border-radius:0;border-bottom:1px solid var(--brd);
    font-size:.9rem;justify-content:flex-start;
  }
  .nav-cta{
    margin:.8rem 1rem .4rem;
    width:calc(100% - 2rem);
    border-radius:var(--r);
    border-bottom:none;
    justify-content:center;
  }

  /* Detail pages stack vertically */
  .addon-detail-header{grid-template-columns:1fr;}
  .addon-detail-content{flex-direction:column;}
  .field-row{grid-template-columns:1fr;}
}

/* ══════════════════════════════════════
   RESPONSIVE ≤ 640px — SMALL MOBILE
══════════════════════════════════════ */
@media(max-width:640px){
  :root{--hh:52px;}
  .logo-text{font-size:1.05rem;}
  .page{padding:1.25rem 0 3rem;}
  .pg-title,.page-title{font-size:1.3rem;}
  .auth-card{padding:1.5rem 1rem;border-radius:var(--rl);}
  .addon-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));}
  .filter-bar{flex-direction:column;align-items:stretch;}
  .search-wrap,.f-select,.filter-bar>.btn{width:100%;}
  .meta-actions{flex-direction:column;}
  .upload-box{padding:1.4rem .9rem;}
  .toast{bottom:12px;padding:9px 14px;font-size:.8rem;}
  .addon-detail-skeleton{grid-template-columns:1fr;}
}

/* ══════════════════════════════════════
   RESPONSIVE ≤ 360px — TINY SCREEN
══════════════════════════════════════ */
@media(max-width:360px){
  .comm-grid{grid-template-columns:repeat(2,1fr);}
  .container{width:96%;}
}
