:root{
  --bg:#0f1116;
  --bg-soft:#171a21;
  --card:#181b22;
  --card-2:#1d2129;
  --text:#f5f7fb;
  --muted:#a8afbb;
  --line:rgba(255,255,255,.08);
  --accent:#ff7a18;
  --accent-2:#ff9a1f;
  --accent-dark:#d65f00;
  --shadow:0 14px 34px rgba(0,0,0,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:linear-gradient(180deg,#0d1015,#12151c 30%,#101318);color:var(--text)}
a{text-decoration:none;color:inherit}img{max-width:100%;display:block}
.container{width:min(1380px,calc(100% - 36px));margin:0 auto}
.topbar{position:sticky;top:0;z-index:40;background:rgba(10,12,16,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px;font-size:28px;font-weight:700}
.brand-logo{width:44px;height:44px;object-fit:contain;border-radius:50%;box-shadow:0 6px 16px rgba(0,0,0,.25)}
.brand-text strong{color:var(--accent)}
.nav-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.status-pill,.input,.panel,.hero-box,.flash,.filters-card,.intro-card{border:1px solid var(--line);background:rgba(255,255,255,.03)}
.status-pill{color:var(--muted);padding:10px 14px;border-radius:999px;font-size:14px}
.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;background:#fff;color:#222;cursor:pointer;border-radius:12px;padding:11px 16px;font-size:15px;font-weight:700;transition:.18s ease}
.btn:hover{transform:translateY(-1px)}
.btn-accent{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 10px 20px rgba(255,122,24,.2)}
.btn-green{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 10px 20px rgba(255,122,24,.2)}
.btn-outline{border-color:var(--line);background:rgba(255,255,255,.03);color:var(--text)}
.btn-dark{border-color:rgba(255,255,255,.12);background:rgba(0,0,0,.32);color:#fff}
.page{padding:26px 0 34px}.page-home{padding-bottom:40px}.section-gap{padding-top:8px}
.hero-box,.panel,.main-media,.detail-content,.filters-card,.intro-card{border-radius:18px;box-shadow:var(--shadow)}
.hero-box{padding:18px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02))}
.hero-top{display:flex;justify-content:space-between;gap:20px;align-items:center;flex-wrap:wrap}.hero-top h1{margin:0 0 8px;font-size:34px}.hero-top p,.muted{color:var(--muted);line-height:1.55}
.hero-banner-wrap{padding:22px 0 8px}.hero-banner{position:relative;min-height:440px;border-radius:24px;overflow:hidden;box-shadow:0 24px 50px rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.08)}
.hero-banner-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,10,12,.82) 0%,rgba(10,10,12,.45) 36%,rgba(10,10,12,.12) 100%)}
.hero-content{position:relative;z-index:2;max-width:620px;padding:56px 48px}
.hero-badge,.eyebrow{display:inline-block;padding:8px 12px;border-radius:999px;background:rgba(255,122,24,.14);border:1px solid rgba(255,122,24,.3);color:#ffd5b3;font-size:13px;font-weight:700;letter-spacing:.03em;text-transform:uppercase}
.hero-content h1{margin:18px 0 14px;font-size:clamp(2.2rem,4vw,4.1rem);line-height:1.02}
.hero-content p{margin:0;color:#d5dbe6;font-size:1.05rem;line-height:1.65;max-width:56ch}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.intro-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:18px}
.intro-card{padding:18px 20px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.025))}
.intro-card strong{display:block;margin-bottom:6px;font-size:1rem}.intro-card span{color:var(--muted);line-height:1.5;font-size:.95rem}
.section-head{display:flex;justify-content:space-between;gap:16px;align-items:end;margin-bottom:18px}.section-head h2{margin:8px 0 4px;font-size:2rem}
.filters{margin:18px 0}.filters-card{padding:14px}.input{height:48px;border-radius:12px;padding:0 16px;font-size:15px;color:var(--text)}.input::placeholder{color:#929aaa}.full{width:100%}.area{height:140px;padding:12px 14px;background:rgba(255,255,255,.02)}
.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}.card{background:transparent}
.vehicle-card{background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:var(--shadow);transition:.18s ease}
.vehicle-card:hover{transform:translateY(-3px);border-color:rgba(255,122,24,.45);box-shadow:0 18px 34px rgba(0,0,0,.34)}
.thumb-wrap{position:relative;border-radius:14px;overflow:hidden;background:#1f2229;aspect-ratio:16/9}.thumb{width:100%;height:100%;object-fit:cover}.thumb-meta{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-between;align-items:center;padding:10px 10px 8px;color:#fff;font-size:12px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.82))}.thumb-stats{display:flex;gap:10px}.card-body{padding:12px 4px 4px}.card-title{margin:0 0 8px;font-size:18px;line-height:1.32}.card-author{color:var(--muted);font-size:13px}.card-author span,.creator-name,.back-link{color:var(--accent)}.card-category{margin-top:10px;display:inline-block;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;background:rgba(255,122,24,.1);border:1px solid rgba(255,122,24,.22);color:#ffcb9e}
.version{background:#2b313d;color:#fff;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700;display:inline-block;margin-left:8px;vertical-align:middle}
.detail-layout{display:grid;grid-template-columns:400px minmax(0,1fr);gap:20px;align-items:start}.panel{overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.02))}.panel-pad{padding:16px}
.download-big{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:30px;font-weight:700;padding:24px 20px;text-align:center;display:block}.action-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px}.mini-btn{border:1px solid rgba(255,122,24,.2);border-radius:12px;background:rgba(255,255,255,.02);color:#ffd1ad;text-align:center;padding:14px 8px;font-weight:700;font-size:13px;min-height:66px}.detail-title{margin:0 0 12px;font-size:34px}.main-media{background:rgba(255,255,255,.03);border:1px solid var(--line);overflow:hidden}.main-image{width:100%;aspect-ratio:16/9;object-fit:cover}.gallery-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;padding:10px;border-top:1px solid var(--line)}.gallery-thumb{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:10px;cursor:pointer;border:2px solid transparent}.gallery-thumb.active{border-color:var(--accent)}
.detail-stats{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:14px}.stats-left{display:flex;gap:22px;flex-wrap:wrap}.stat-big{font-size:14px;color:var(--muted)}.stat-big strong{display:block;color:var(--accent);font-size:32px;line-height:1.05}.rating{text-align:right;font-size:14px}.detail-content{background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.02));border:1px solid var(--line);padding:20px;line-height:1.7}.flash{margin-top:12px;padding:12px 14px;border-radius:12px}.flash-success{border-color:rgba(255,122,24,.3);background:rgba(255,122,24,.08)}.flash-error{border-color:#7d3232;background:#2a1515}.mt16{margin-top:16px}.narrow{max-width:540px}.narrowish{max-width:860px}.admin-form label{display:block;margin:12px 0 6px;font-weight:700}
@media(max-width:1200px){.grid{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-layout{grid-template-columns:1fr}.hero-banner{min-height:390px}}
@media(max-width:980px){.intro-strip{grid-template-columns:1fr}.hero-content{padding:40px 28px}.hero-overlay{background:linear-gradient(180deg,rgba(10,10,12,.78) 0%,rgba(10,10,12,.55) 44%,rgba(10,10,12,.38) 100%)}}
@media(max-width:820px){.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.gallery-row{grid-template-columns:repeat(3,1fr)}.action-grid{grid-template-columns:repeat(2,1fr)}.status-pill{display:none}}
@media(max-width:560px){.container{width:min(100%,calc(100% - 20px))}.grid{grid-template-columns:1fr}.hero-content h1,.hero-top h1,.detail-title{font-size:28px}.download-big{font-size:24px}.brand-text{font-size:22px}.brand-logo{width:38px;height:38px}.hero-banner{min-height:340px}.hero-content{padding:26px 18px}.topbar-inner{padding:10px 0}.nav-actions{gap:8px}.btn{padding:10px 12px;font-size:14px}}


/* ===== NUR Fahrzeugkarten-Bilder auf 16:9 setzen ===== */

.vehicle-grid,
.cards-grid,
.upload-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
}

/* Karte selbst unverändert lassen, nur sauber halten */
.vehicle-card,
.card,
.upload-card {
    overflow: hidden;
}

/* Alle typischen Bild-Wrapper auf 16:9 zwingen */
.vehicle-card .thumb-wrap,
.vehicle-card .vehicle-card-image,
.vehicle-card .card-image,
.vehicle-card .vehicle-cover,
.card .thumb-wrap,
.card .card-image,
.card .vehicle-cover,
.upload-card .thumb-wrap,
.upload-card .card-image,
.upload-card .vehicle-cover {
    width: 100% !important;
    aspect-ratio: 16 / 9 !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
    display: block !important;
    border-radius: 10px;
}

/* Bilder darin korrekt füllen */
.vehicle-card .thumb-wrap img,
.vehicle-card .vehicle-card-image img,
.vehicle-card .card-image img,
.vehicle-card .vehicle-cover img,
.card .thumb-wrap img,
.card .card-image img,
.card .vehicle-cover img,
.upload-card .thumb-wrap img,
.upload-card .card-image img,
.upload-card .vehicle-cover img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

/* Falls das Bild direkt in der Karte liegt */
.vehicle-card > img,
.card > img,
.upload-card > img {
    width: 100% !important;
    aspect-ratio: 16 / 9 !important;
    height: auto !important;
    object-fit: cover !important;
    display: block !important;
    border-radius: 10px;
}

/* ===== Portal visual cleanup ===== */
.portal-page{
  padding-top: 8px;
}
.portal-head{
  margin-bottom: 16px;
}
.portal-head h2{
  margin: 8px 0 6px;
  font-size: 2.2rem;
}
.portal-toolbar{
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0 0 22px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
}
.portal-tabs{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.portal-tab{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 16px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: .18s ease;
}
.portal-tab:hover{
  transform: translateY(-1px);
  border-color: rgba(255,122,24,.45);
}
.portal-tab.is-active{
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  border-color: transparent;
  box-shadow: 0 10px 24px rgba(255,122,24,.24);
}
.portal-tools{
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 14px;
  align-items: end;
}
.portal-search-wrap{
  width: 100%;
}
.portal-search-input{
  width: 100%;
}
.portal-sort-wrap{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.portal-sort-wrap label{
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted);
}
.portal-select{
  height: 48px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 0 14px;
  outline: none;
}
.portal-grid{
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.portal-grid .vehicle-card{
  padding: 10px;
}
.portal-grid .card-body{
  padding: 12px 4px 4px;
}
.portal-grid .card-title{
  font-size: 1.15rem;
  line-height: 1.25;
  min-height: 56px;
  margin: 0 0 8px;
}
.portal-grid .card-author{
  margin-bottom: 10px;
}
.portal-grid .card-category{
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255,122,24,.12);
  border: 1px solid rgba(255,122,24,.28);
  color: #ffd1ad;
  font-size: 12px;
  font-weight: 700;
}
@media (max-width: 1100px){
  .portal-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 820px){
  .portal-tools{
    grid-template-columns: 1fr;
  }
  .portal-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 560px){
  .portal-grid{
    grid-template-columns: 1fr;
  }
}

.hero-stats{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.hero-stat{min-width:120px;padding:14px 16px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);backdrop-filter:blur(8px)}
.hero-stat strong{display:block;font-size:1.45rem;line-height:1.1}
.hero-stat span{display:block;margin-top:4px;color:#d5dbe6;font-size:.92rem}
.portal-results-row{display:flex;justify-content:flex-end;align-items:center}
.portal-results-copy{margin:0;color:var(--muted);font-size:.95rem}
.portal-results-copy span{color:var(--text);font-weight:700}
.empty-state{margin-top:18px;padding:22px;border-radius:18px;border:1px dashed rgba(255,255,255,.16);background:rgba(255,255,255,.02);text-align:center}
.empty-state strong{display:block;margin-bottom:6px;font-size:1.05rem}
.empty-state p{margin:0;color:var(--muted)}
.detail-shell{display:grid;grid-template-columns:minmax(0,1.4fr) 360px;gap:22px;align-items:start}
.detail-main,.detail-sidebar{display:flex;flex-direction:column;gap:16px}
.detail-panel,.detail-hero-media{border-radius:20px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.02));box-shadow:var(--shadow)}
.detail-hero-media{overflow:hidden}
.detail-main-image{display:block;width:100%;aspect-ratio:16/9;object-fit:cover}
.detail-gallery-row{border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.025)}
.detail-copy{padding:22px}
.detail-topline{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.detail-author-chip{display:inline-flex;align-items:center;min-height:30px;padding:4px 10px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);color:var(--muted);font-size:12px;font-weight:700}
.detail-page-title{margin:0 0 14px;font-size:clamp(2rem,3vw,3rem);line-height:1.05}
.detail-summary{color:#d5dbe6;line-height:1.75}
.detail-download-panel{padding:0 0 16px;overflow:hidden}.detail-download-btn{border-radius:18px 18px 0 0}
.detail-action-stack{display:grid;grid-template-columns:1fr;gap:10px;padding:14px 16px 0}
.detail-info-panel{padding:18px}
.detail-side-title{margin:0 0 14px;font-size:1.1rem}
.detail-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.detail-meta-item{padding:14px;border-radius:14px;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.03)}
.detail-meta-label{display:block;margin-bottom:6px;color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}
@media(max-width:1100px){.detail-shell{grid-template-columns:1fr}.detail-sidebar{order:-1}}
@media(max-width:560px){.hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.detail-meta-grid{grid-template-columns:1fr}.portal-results-row{justify-content:flex-start}}

.narrow{max-width:760px}.narrowish{max-width:980px}
.mt16{margin-top:16px}
.panel-pad{padding:24px}
.input{width:100%;padding:12px 14px;border-radius:12px;color:var(--text);outline:none}
.input::placeholder{color:#7f8896}.area{min-height:140px;resize:vertical}
.select{appearance:none}
.form-grid{display:grid;gap:16px}.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}
.admin-form{display:flex;flex-direction:column;gap:16px}.admin-form label{display:block;margin:0 0 8px;font-size:.92rem;font-weight:700}
.admin-form-head,.admin-toolbar{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap;margin-bottom:18px}
.admin-form-actions{display:flex;gap:12px;flex-wrap:wrap}
.form-help{margin:0}
.flash{margin-top:14px;padding:14px 16px;border-radius:14px}.flash-success{border-color:rgba(71,196,122,.28);background:rgba(71,196,122,.08)}.flash-error{border-color:rgba(255,107,107,.28);background:rgba(255,107,107,.08)}.flash-info{border-color:rgba(91,165,255,.28);background:rgba(91,165,255,.08)}
.back-link{display:inline-flex;margin-bottom:18px;color:#d7ddea}
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.card{overflow:hidden;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.025));box-shadow:var(--shadow)}
.thumb{width:100%;aspect-ratio:16/10;object-fit:cover}.thumb-wrap{display:block;position:relative}.thumb-meta{position:absolute;left:12px;right:12px;bottom:12px;display:flex;justify-content:space-between;gap:10px;color:#fff;font-size:.88rem}.thumb-meta>div{padding:8px 10px;border-radius:999px;background:rgba(0,0,0,.44);backdrop-filter:blur(10px)}.thumb-stats{display:flex;gap:8px}
.card-body{padding:16px}.card-title{margin:0 0 8px;font-size:1.08rem}.card-author{color:var(--muted);margin-bottom:12px}.card-author span{color:var(--text)}.card-category{display:inline-flex;padding:7px 10px;border-radius:999px;background:rgba(255,122,24,.12);border:1px solid rgba(255,122,24,.24);color:#ffd4b2;font-size:.82rem;font-weight:700}
.portal-page{display:flex;flex-direction:column;gap:18px}.portal-head h2,.admin-section-title{margin:0 0 8px;font-size:1.8rem}
.portal-toolbar{padding:18px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.03);display:flex;flex-direction:column;gap:16px}.portal-tabs{display:flex;gap:10px;flex-wrap:wrap}.portal-tab{padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text);cursor:pointer}.portal-tab.is-active{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent}.portal-tools{display:flex;gap:14px;flex-wrap:wrap}.portal-search-wrap{flex:1 1 340px}.portal-sort-wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.portal-select{min-width:200px;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text)}
.gallery-row{display:flex;gap:12px;padding:12px;overflow:auto}.gallery-thumb{width:132px;height:80px;object-fit:cover;border-radius:14px;border:2px solid transparent;cursor:pointer}.gallery-thumb.active{border-color:var(--accent)}
.download-big{display:flex;align-items:center;justify-content:center;min-height:70px;padding:18px 20px;font-size:1.06rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}
.mini-btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:10px 14px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);font-weight:700;cursor:pointer}.mini-btn[disabled]{opacity:.65;cursor:not-allowed}
.admin-stats-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-top:18px}.admin-stat-card{padding:16px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04)}.admin-stat-card span{display:block;color:var(--muted);font-size:.84rem;margin-bottom:6px}.admin-stat-card strong{font-size:1.55rem}
.admin-toolbar-controls{display:flex;gap:12px;flex-wrap:wrap}.admin-toolbar-controls .input{min-width:220px}
.admin-table-wrap{overflow:auto}.admin-table{width:100%;border-collapse:collapse;min-width:980px}.admin-table th,.admin-table td{padding:14px 10px;border-bottom:1px solid rgba(255,255,255,.07);text-align:left;vertical-align:middle}.vehicle-admin-cell{display:flex;gap:12px;align-items:center}.vehicle-admin-cell img{width:74px;height:54px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.08)}.admin-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-small{padding:9px 12px;font-size:.86rem}.btn-danger{background:rgba(255,91,91,.14);border-color:rgba(255,91,91,.24);color:#ffd5d5}
.screenshot-grid{margin-top:4px}
.login-panel{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;align-items:stretch}.login-copy{padding:8px 4px}.login-copy h1{margin:12px 0}.login-checks{display:flex;flex-direction:column;gap:10px;margin-top:18px;color:#d5dbe6}.login-form-card{padding:20px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.access-card{padding:16px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}.access-card strong{display:block;margin-bottom:8px}.access-card p{margin:0;color:var(--muted);line-height:1.6}.access-card.is-ready{border-color:rgba(71,196,122,.22);background:rgba(71,196,122,.06)}.access-card.is-locked{border-color:rgba(255,173,51,.18);background:rgba(255,173,51,.05)}
.role-pill-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.role-pill{display:inline-flex;padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#d7ddea;font-size:.84rem}.role-pill.is-owned{border-color:rgba(71,196,122,.24);background:rgba(71,196,122,.1)}
@media(max-width:1180px){.admin-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:820px){.topbar-inner,.login-panel{grid-template-columns:1fr;display:flex;flex-direction:column}.hero-content{padding:36px 24px}.hero-banner{min-height:380px}.intro-strip,.two-col,.grid{grid-template-columns:1fr}.portal-tools,.admin-toolbar-controls{flex-direction:column}.portal-select,.admin-toolbar-controls .input{width:100%}.container{width:min(100%,calc(100% - 24px))}.admin-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.btn,.mini-btn{width:100%}.full-mobile{width:100%}.hero-top h1,.detail-page-title{font-size:2rem}.admin-form-actions{flex-direction:column}.portal-results-row{justify-content:flex-start}}

.discord-user-chip,
.access-user-row{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:44px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--text);
  font-weight:700;
}
.discord-user-avatar,
.access-user-avatar{
  width:28px;
  height:28px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.12);
}
.access-user-row{
  margin:12px 0 0;
}
.flash-info{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
}
@media(max-width:820px){
  .discord-user-chip{
    max-width:100%;
  }
}

.subcategory-filter-wrap{display:flex;flex-direction:column;gap:14px;padding:14px;border-radius:16px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06)}
.subcategory-block{display:flex;flex-direction:column;gap:10px}.subcategory-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.chip-row{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{padding:9px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:var(--text);font-weight:700;cursor:pointer}.filter-chip.is-active{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent}
.card-category-stack{display:flex;flex-wrap:wrap;gap:8px}.card-category-sub{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08);color:#dfe6f0}
.category-manager-grid{display:grid;grid-template-columns:380px minmax(0,1fr);gap:18px}.category-tree{display:flex;flex-direction:column;gap:14px}.category-tree-item{border:1px solid var(--line);border-radius:16px;padding:14px;background:rgba(255,255,255,.02)}.category-tree-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.category-tree-children{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:10px}.category-tree-row.child{padding-left:14px}
@media(max-width:900px){.category-manager-grid{grid-template-columns:1fr}}

.portal-tab-rich{display:flex;align-items:center;gap:10px}
.portal-tab-image{width:24px;height:24px;object-fit:cover;border-radius:6px;border:1px solid rgba(255,255,255,.08)}
.compact-subcategory-wrap{padding:8px 0 0;border:none;background:transparent}
.compact-subcategory-wrap .chip-row{justify-content:flex-start}
.checkbox-row{display:flex;align-items:center;gap:8px;color:var(--muted)}
.main-category-stack{display:flex;flex-direction:column;gap:14px}
.main-category-item{padding:16px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(255,255,255,.03)}
.main-category-item-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}
.main-category-item-actions,.main-category-delete-form{display:flex;justify-content:flex-end}


.compact-category-tabs{gap:8px;align-items:center}
.compact-category-tabs .portal-tab{min-height:40px;padding:9px 14px;border-radius:999px}
.inline-under-tabs{margin-top:-6px;padding-top:0}
.inline-under-tabs .chip-row{gap:7px}
.inline-under-tabs .chip-row + .chip-row{margin-top:2px}
.portal-tab-rich{gap:8px}
.portal-tab-image{width:18px;height:18px;border-radius:4px}
.mt8{margin-top:8px}
.image-preview-card{padding:8px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.025)}
.image-preview-thumb{display:block;width:100%;height:140px;object-fit:cover;border-radius:10px;background:rgba(255,255,255,.03)}
.image-preview-thumb.is-empty{height:88px;object-fit:contain;opacity:.45}
.screenshot-grid .image-preview-thumb{height:120px}
@media(max-width:820px){.image-preview-thumb,.screenshot-grid .image-preview-thumb{height:110px}}

/* ===== Final frontend fixes: compact example layout + 4-card grid ===== */
.portal-page{gap:16px}
.portal-toolbar-example{
  padding:14px 16px 16px;
  gap:12px;
}
.portal-tabs-example{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
  gap:0;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.02));
}
.portal-tab-example{
  min-height:128px;
  border-radius:0;
  border:0;
  border-right:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:18px 10px 16px;
}
.portal-tab-example:last-child{border-right:0}
.portal-tab-example:hover{transform:none;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02))}
.portal-tab-example.is-active{
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));
  color:#fff;
  box-shadow:none;
  position:relative;
}
.portal-tab-example.is-active::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:4px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
}
.portal-tab-image{
  width:58px;
  height:58px;
  object-fit:contain;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.22));
}
.portal-tab-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:58px;
  height:58px;
  font-size:46px;
  line-height:1;
}
.portal-tab-label{
  font-size:14px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.subcategory-filter-inline{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:-2px;
}
.chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.filter-chip{
  min-height:28px;
  padding:4px 10px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.035);
  color:#d9dde5;
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.02em;
  cursor:pointer;
}
.filter-chip:hover{border-color:rgba(255,122,24,.35)}
.filter-chip.is-active{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  border-color:transparent;
  color:#fff;
  box-shadow:0 8px 18px rgba(255,122,24,.24);
}
.portal-tools{
  display:grid;
  grid-template-columns:minmax(0,1fr) 220px;
  gap:12px;
  align-items:end;
}
.portal-sort-wrap{align-items:stretch}
.portal-sort-wrap label{margin:0 0 6px}
.portal-results-row{margin-top:-2px}
.portal-grid{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:16px;
}
.portal-grid .vehicle-card{
  padding:10px;
  min-width:0;
}
.portal-grid .thumb-wrap{
  aspect-ratio:16 / 9 !important;
  border-radius:14px;
  overflow:hidden;
}
.portal-grid .thumb{
  width:100%;
  height:100%;
  object-fit:cover;
}
.portal-grid .thumb-meta{
  left:0;
  right:0;
  bottom:0;
  padding:10px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.82));
}
.portal-grid .thumb-meta > div{
  max-width:calc(50% - 6px);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.portal-grid .card-title{
  font-size:1.05rem;
  min-height:48px;
}
.card-category-stack{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.card-category-sub{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);color:#d9dde5}
@media (max-width: 1180px){
  .portal-grid{grid-template-columns:repeat(3,minmax(0,1fr)) !important;}
}
@media (max-width: 840px){
  .portal-tabs-example{grid-template-columns:repeat(2,minmax(0,1fr));}
  .portal-tab-example{min-height:104px;gap:8px}
  .portal-tools{grid-template-columns:1fr;}
  .portal-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media (max-width: 560px){
  .portal-grid{grid-template-columns:1fr !important;}
  .portal-tab-image,.portal-tab-icon{width:42px;height:42px;font-size:34px}
  .portal-tab-label{font-size:12px}
}

/* ===== 2026 design refresh ===== */
:root{
  --surface:rgba(255,255,255,.035);
  --surface-2:rgba(255,255,255,.05);
  --surface-3:rgba(255,255,255,.07);
  --shadow-soft:0 18px 50px rgba(0,0,0,.26);
}
body{
  background:
    radial-gradient(circle at top center, rgba(255,122,24,.10), transparent 28%),
    linear-gradient(180deg,#0b0e13 0%, #11151d 38%, #0d1117 100%);
}
.topbar{
  background:rgba(8,10,14,.78);
  box-shadow:0 8px 30px rgba(0,0,0,.16);
}
.topbar-inner{
  padding:14px 0;
}
.topbar-brand-wrap{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.brand{
  gap:14px;
  letter-spacing:-.02em;
}
.brand-logo{
  width:46px;
  height:46px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}
.brand-subline{
  color:var(--muted);
  font-size:12px;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.nav-actions{
  gap:12px;
}
.status-pill,
.discord-user-chip,
.access-user-row{
  background:rgba(255,255,255,.045);
  border-color:rgba(255,255,255,.09);
}
.btn{
  min-height:46px;
  border-radius:14px;
}
.btn-outline,
.btn-dark,
.mini-btn,
.portal-select,
.input{
  background:rgba(255,255,255,.04);
}
.btn-outline:hover,
.btn-dark:hover,
.mini-btn:hover,
.vehicle-card:hover{
  box-shadow:var(--shadow-soft);
}
.hero-banner-refined{
  min-height:460px;
  border-radius:28px;
  border-color:rgba(255,255,255,.09);
}
.hero-overlay{
  background:
    linear-gradient(90deg,rgba(8,10,14,.88) 0%, rgba(8,10,14,.62) 42%, rgba(8,10,14,.18) 100%),
    linear-gradient(180deg,rgba(255,122,24,.10),transparent 55%);
}
.hero-content{
  max-width:700px;
  padding:62px 56px;
}
.hero-content h1{
  margin:20px 0 12px;
  letter-spacing:-.04em;
}
.hero-content p{
  color:#dee5ef;
  max-width:58ch;
}
.hero-actions{
  margin-top:28px;
}
.hero-stats{
  gap:14px;
  margin-top:30px;
}
.hero-stat{
  min-width:138px;
  padding:15px 18px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  border-color:rgba(255,255,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.portal-page{
  gap:20px;
}
.portal-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
}
.portal-head-copy{
  max-width:72ch;
}
.portal-surface,
.detail-panel,
.detail-gallery-row,
.site-footer-inner{
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.022));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow-soft);
}
.portal-toolbar-example{
  padding:18px;
  gap:14px;
  border-radius:22px;
}
.portal-tabs-example{
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
}
.portal-tab-example{
  min-height:132px;
  padding:18px 12px;
}
.portal-tab-example.is-active{
  background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.04));
}
.portal-tab-label{
  letter-spacing:.06em;
}
.subcategory-filter-wrap{
  padding:12px 0 0;
  border:none;
  background:transparent;
}
.filter-chip{
  min-height:32px;
  padding:6px 11px;
  border-radius:999px;
}
.portal-search-input,
.portal-select{
  height:50px;
  border-radius:14px;
}
.portal-results-row{
  padding-top:2px;
  border-top:1px solid rgba(255,255,255,.06);
}
.portal-grid{
  gap:18px !important;
}
.portal-grid .vehicle-card{
  padding:12px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.025));
  border:1px solid rgba(255,255,255,.08);
}
.portal-grid .thumb-wrap{
  border-radius:16px;
  background:#151920;
}
.portal-grid .thumb{
  transition:transform .35s ease;
}
.portal-grid .vehicle-card:hover .thumb{
  transform:scale(1.035);
}
.portal-grid .thumb-meta{
  padding:12px;
}
.portal-grid .thumb-meta > div{
  padding:8px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.44);
  backdrop-filter:blur(10px);
}
.portal-grid .card-body{
  padding:15px 4px 4px;
}
.portal-grid .card-title{
  min-height:50px;
  font-size:1.08rem;
  letter-spacing:-.015em;
}
.card-title-link{
  transition:color .18s ease;
}
.vehicle-card:hover .card-title-link{
  color:#fff0e2;
}
.portal-grid .card-author{
  font-size:.92rem;
  margin-bottom:12px;
}
.card-category,
.card-category-sub{
  min-height:32px;
  align-items:center;
}
.empty-state{
  border-radius:20px;
  border-style:solid;
}
.detail-page{
  padding-top:22px;
}
.back-link{
  margin-bottom:20px;
  color:#f1c6a1;
}
.detail-shell{
  gap:24px;
}
.detail-hero-media,
.detail-gallery-row,
.detail-panel{
  border-radius:24px;
}
.detail-copy{
  padding:24px;
}
.detail-page-title{
  letter-spacing:-.035em;
}
.detail-quick-stats{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin:0 0 18px;
}
.detail-quick-stat{
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.035);
}
.detail-quick-stat span{
  display:block;
  margin-bottom:6px;
  color:var(--muted);
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.detail-quick-stat strong{
  font-size:1.2rem;
}
.detail-summary{
  color:#dce3ed;
}
.detail-download-panel{
  overflow:hidden;
}
.detail-download-btn{
  min-height:78px;
  font-size:1.1rem;
}
.detail-action-stack{
  padding:16px;
}
.detail-meta-item,
.access-card,
.role-pill,
.site-footer-pill{
  border-color:rgba(255,255,255,.08);
}
.site-footer{
  padding:8px 0 26px;
}
.site-footer-inner{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  padding:18px 22px;
  border-radius:22px;
}
.site-footer-brand{
  font-size:1.15rem;
  font-weight:800;
}
.site-footer-brand strong{
  color:var(--accent);
}
.site-footer-copy{
  margin:6px 0 0;
  color:var(--muted);
  max-width:62ch;
}
.site-footer-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-end;
}
.site-footer-pill{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  color:#dce3ed;
  border:1px solid rgba(255,255,255,.08);
  font-size:.88rem;
  font-weight:700;
}
@media (max-width: 980px){
  .hero-content{
    padding:44px 34px;
  }
  .hero-overlay{
    background:linear-gradient(180deg,rgba(8,10,14,.84) 0%, rgba(8,10,14,.6) 50%, rgba(8,10,14,.36) 100%);
  }
  .site-footer-inner{
    flex-direction:column;
    align-items:flex-start;
  }
  .site-footer-meta{
    justify-content:flex-start;
  }
}
@media (max-width: 840px){
  .topbar-brand-wrap{
    width:100%;
  }
  .nav-actions{
    width:100%;
    justify-content:flex-start;
  }
  .portal-head{
    align-items:flex-start;
  }
}
@media (max-width: 640px){
  .hero-banner-refined{
    min-height:380px;
  }
  .hero-content{
    padding:28px 20px;
  }
  .brand-subline{
    display:none;
  }
  .detail-quick-stats{
    grid-template-columns:1fr;
  }
  .site-footer{
    padding-bottom:18px;
  }
}


/* Cleaner home layout */
.hero-content-clean {
  justify-content: flex-end;
  align-items: flex-start;
  min-height: 100%;
}
.portal-head-compact {
  display: none;
}


/* ===== Hero cleanup v2 ===== */
.hero-shell{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.hero-banner-cleanonly{
  min-height:324px;
}
.hero-banner-image-focused{
  object-position:50% 18%;
}
.hero-overlay-soft{
  background:
    linear-gradient(180deg,rgba(8,10,14,.28) 0%, rgba(8,10,14,.12) 44%, rgba(8,10,14,.34) 100%),
    linear-gradient(90deg,rgba(8,10,14,.16) 0%, rgba(8,10,14,0) 46%, rgba(8,10,14,.14) 100%);
}
.hero-utility-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 16px;
  border-radius:20px;
}
.hero-utility-actions,
.hero-utility-stats{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.hero-utility-actions .btn{
  min-height:44px;
  padding:11px 16px;
}
.hero-utility-stats{
  margin-left:auto;
}
.hero-utility-bar .hero-stat{
  min-width:118px;
  padding:12px 14px;
  border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:none;
}
.hero-utility-bar .hero-stat strong{
  display:block;
  font-size:1.35rem;
  line-height:1.05;
}
.hero-utility-bar .hero-stat span{
  display:block;
  margin-top:3px;
  font-size:.86rem;
  color:#cfd7e3;
}
@media (max-width: 980px){
  .hero-banner-cleanonly{
    min-height:300px;
  }
  .hero-banner-image-focused{
    object-position:58% 16%;
  }
  .hero-utility-bar{
    flex-direction:column;
    align-items:flex-start;
  }
  .hero-utility-stats{
    margin-left:0;
  }
}
@media (max-width: 640px){
  .hero-banner-cleanonly{
    min-height:240px;
    border-radius:22px;
  }
  .hero-banner-image-focused{
    object-position:63% 14%;
  }
  .hero-utility-bar{
    padding:12px;
    border-radius:18px;
  }
  .hero-utility-actions,
  .hero-utility-stats{
    width:100%;
  }
  .hero-utility-actions .btn,
  .hero-utility-bar .hero-stat{
    flex:1 1 calc(50% - 6px);
    min-width:0;
  }
}



/* HERO BANNER DESKTOP IMPROVEMENT */
.hero-banner{
    height: clamp(380px,32vw,500px);
    overflow:hidden;
    border-radius:18px;
}

.hero-banner img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center 34%;
}


/* ===== Design polish pack: cards, detail page, admin ===== */
.hero-banner-refined::after,
.hero-banner-cleanonly::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(5,8,12,.10) 0%, rgba(5,8,12,.04) 22%, rgba(5,8,12,.22) 72%, rgba(5,8,12,.34) 100%),
    radial-gradient(circle at 18% 20%, rgba(255,122,24,.08), transparent 34%);
}

.portal-grid .vehicle-card{
  position:relative;
  overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}
.portal-grid .vehicle-card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent 28%, rgba(255,122,24,.03) 100%);
  opacity:.9;
}
.portal-grid .vehicle-card:hover{
  transform:translateY(-6px);
  border-color:rgba(255,122,24,.24);
  box-shadow:0 22px 44px rgba(0,0,0,.34);
}
.portal-grid .thumb-wrap{
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
}
.portal-grid .thumb-meta{
  gap:10px;
}
.portal-grid .card-category-stack{
  gap:8px;
}

.detail-page{
  padding-top:26px;
}
.detail-main{
  display:grid;
  gap:18px;
}
.detail-copy.detail-panel,
.detail-info-panel,
.detail-download-panel{
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.024));
}
.detail-copy{
  padding:28px;
}
.detail-topline{
  margin-bottom:12px;
  gap:8px;
}
.detail-page-title{
  margin-bottom:14px;
}
.detail-quick-stats{
  margin-bottom:22px;
}
.detail-summary{
  line-height:1.72;
  font-size:1rem;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.07);
}
.detail-sidebar{
  position:sticky;
  top:86px;
}
.detail-meta-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.detail-meta-item{
  min-height:84px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(255,255,255,.032);
}
.detail-meta-label{
  margin-bottom:10px;
}

.admin-page .hero-box,
.admin-page .panel{
  border-radius:24px;
}
.admin-hero-box{
  padding:22px;
}
.admin-toolbar{
  align-items:flex-end;
  gap:18px;
  margin-bottom:16px;
}
.admin-toolbar-controls .input,
.admin-toolbar-controls .select{
  min-height:46px;
  border-radius:14px;
}
.admin-table-wrap{
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  overflow:auto;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.018));
}
.admin-table{
  min-width:1020px;
}
.admin-table thead th{
  position:sticky;
  top:0;
  z-index:1;
  background:#171b23;
  color:#dfe7f1;
  font-size:.84rem;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.admin-table tbody tr{
  transition:background .18s ease;
}
.admin-table tbody tr:hover{
  background:rgba(255,255,255,.032);
}
.admin-table th,
.admin-table td{
  padding:16px 14px;
}
.vehicle-admin-cell{
  gap:14px;
}
.vehicle-admin-cell img{
  width:88px;
  height:60px;
  border-radius:14px;
  box-shadow:0 10px 24px rgba(0,0,0,.22);
}
.admin-actions .btn-small{
  min-height:40px;
  border-radius:12px;
  padding:9px 13px;
}
.admin-results-row{
  margin-bottom:12px;
}

@media (max-width: 1100px){
  .detail-sidebar{
    position:static;
  }
}
@media (max-width: 700px){
  .detail-meta-grid{
    grid-template-columns:1fr;
  }
  .detail-copy{
    padding:22px;
  }
  .admin-table-wrap{
    border-radius:16px;
  }
}


/* Detail page cleanup: actions inline and reduced meta */
.detail-quick-stats{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.detail-action-stack{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  align-items:stretch;
}
.detail-like-form{
  display:block;
}
.detail-like-form .detail-action-btn,
.detail-action-stack > .detail-action-btn,
.detail-action-btn{
  width:100%;
  min-height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:12px 14px;
}
.detail-action-btn-wide{
  grid-column:1 / -1;
}
.detail-meta-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
@media(max-width:560px){
  .detail-action-stack,
  .detail-quick-stats,
  .detail-meta-grid{
    grid-template-columns:1fr;
  }
}


/* Detail gallery lightbox */
.detail-lightbox-trigger{position:relative;display:block;width:100%;padding:0;border:0;background:none;border-radius:22px;overflow:hidden;cursor:zoom-in;outline:none}
.detail-lightbox-trigger img{display:block;width:100%}
.detail-lightbox-trigger:focus-visible{box-shadow:0 0 0 3px rgba(255,122,24,.35)}
.detail-lightbox-hint{display:none;position:absolute;right:16px;bottom:16px;padding:10px 12px;border-radius:999px;background:rgba(7,10,16,.72);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:13px;font-weight:700;pointer-events:none;transition:opacity .18s ease,transform .18s ease}
.cover-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(9,12,18,.74);backdrop-filter:blur(10px);color:#fff;font-size:34px;line-height:1;display:grid;place-items:center;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease,background .18s ease;z-index:2}
.cover-prev{left:16px}
.cover-next{right:16px}
.detail-lightbox-trigger:hover .cover-nav,
.detail-lightbox-trigger:focus-within .cover-nav{opacity:1;pointer-events:auto}
.detail-lightbox-trigger:hover .cover-prev,
.detail-lightbox-trigger:focus-within .cover-prev{transform:translateY(-50%) translateX(0)}
.detail-lightbox-trigger:hover .cover-next,
.detail-lightbox-trigger:focus-within .cover-next{transform:translateY(-50%) translateX(0)}
.cover-prev{transform:translateY(-50%) translateX(-6px)}
.cover-next{transform:translateY(-50%) translateX(6px)}
.cover-nav:hover{background:rgba(20,25,34,.9)}
.cover-nav[hidden]{display:none !important}
.lightbox-open{overflow:hidden}
.lightbox{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:12px}
.lightbox[hidden]{display:none}
.lightbox-backdrop{position:absolute;inset:0;background:rgba(4,6,10,.9);backdrop-filter:blur(10px)}
.lightbox-dialog{position:relative;z-index:1;width:min(96vw,1900px);height:min(96vh,1200px);display:flex;align-items:center;justify-content:center}
.lightbox-figure{position:relative;margin:0;display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;border-radius:24px;background:rgba(8,11,18,.92);border:1px solid rgba(255,255,255,.08);box-shadow:0 30px 80px rgba(0,0,0,.45)}
.lightbox-image-frame{position:relative;display:inline-block;max-width:96vw;max-height:calc(96vh - 74px);border-radius:18px;overflow:hidden;line-height:0;background:#090c12}
.lightbox-image-frame .lightbox-image{max-width:100%;max-height:calc(96vh - 74px)}
.lightbox-image{display:block;width:auto;height:auto;max-width:96vw;max-height:calc(96vh - 74px);object-fit:contain;background:#090c12}
.lightbox-caption{display:flex;justify-content:center;align-items:center;width:100%;min-height:54px;padding:12px 18px;background:rgba(255,255,255,.03);color:#dfe5ee;font-weight:700}
.lightbox-close,.lightbox-nav{border:1px solid rgba(255,255,255,.14);background:rgba(12,16,24,.76);color:#fff;backdrop-filter:blur(10px);cursor:pointer}
.lightbox-close{position:fixed;top:18px;right:18px;z-index:3;width:48px;height:48px;border-radius:999px;font-size:28px;line-height:1}
.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:3;width:62px;height:62px;border-radius:999px;font-size:38px;display:grid;place-items:center}
.lightbox-prev{left:18px}
.lightbox-next{right:18px}
@media (max-width: 900px){
  .lightbox{padding:8px}
  .lightbox-dialog{width:100%;height:100%}
  .lightbox-figure{border-radius:18px}
  .lightbox-image-frame{max-width:100%;max-height:calc(100vh - 92px)}
  .lightbox-image{max-width:100%;max-height:calc(100vh - 92px)}
  .lightbox-nav{width:54px;height:54px;font-size:32px}
  .lightbox-prev{left:10px}
  .lightbox-next{right:10px}
  .lightbox-close{top:10px;right:10px;width:44px;height:44px}
  .detail-lightbox-hint{right:12px;bottom:12px;padding:8px 10px;font-size:12px}
  .cover-nav{opacity:.95;pointer-events:auto;width:48px;height:48px;font-size:30px}
  .cover-prev{left:10px;transform:translateY(-50%)}
  .cover-next{right:10px;transform:translateY(-50%)}
}



/* Performance and admin comfort refinements */
.portal-grid .thumb,
.gallery-thumb,
.portal-tab-image,
.vehicle-admin-cell img,
.image-preview-thumb,
.discord-user-avatar,
.access-user-avatar{
  content-visibility:auto;
}

.hero-banner{
  contain:layout paint;
}
.portal-grid .thumb-wrap,
.detail-hero-media,
.gallery-row,
.vehicle-admin-cell img,
.image-preview-card{
  contain:layout paint;
}

.admin-hero-box,
.admin-panel-surface,
.category-manager-grid > .panel,
.admin-grid-form,
.admin-form{
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 40px rgba(0,0,0,.22);
}
.admin-form-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:24px;
  padding-bottom:18px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.admin-form-head .hero-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.admin-grid-form{
  padding:22px;
  border-radius:20px;
  background:rgba(255,255,255,.02);
}
.admin-grid-form label,
.admin-form label{
  display:block;
  margin-bottom:8px;
  color:#dfe7f1;
  font-weight:700;
}
.admin-grid-form .input,
.admin-form .input,
.admin-grid-form textarea{
  min-height:50px;
  border-radius:14px;
  background:#121720;
  border:1px solid rgba(255,255,255,.09);
}
.admin-grid-form .area{
  min-height:180px;
}
.admin-form-actions{
  display:flex;
  justify-content:flex-end;
  gap:12px;
  padding-top:6px;
}
.image-preview-card{
  padding:10px;
  border-radius:16px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.06);
}
.admin-toolbar{
  align-items:end;
  gap:18px;
  margin-bottom:18px;
}
.admin-toolbar-controls{
  display:grid;
  grid-template-columns:minmax(220px,1.4fr) minmax(170px,.8fr);
  gap:12px;
}
.admin-table td:last-child,
.admin-table th:last-child{
  width:1%;
  white-space:nowrap;
}
.admin-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.vehicle-admin-cell{
  display:flex;
  align-items:center;
}
.category-manager-grid{
  display:grid;
  grid-template-columns:minmax(320px,420px) minmax(0,1fr);
  gap:18px;
}
.category-tree-item{
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
}
.category-tree-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.category-tree-children{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.06);
  display:grid;
  gap:12px;
}
.category-tree-row.child{
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,255,255,.025);
}
@media (max-width: 980px){
  .admin-form-head,
  .admin-toolbar{
    flex-direction:column;
    align-items:stretch;
  }
  .admin-toolbar-controls,
  .category-manager-grid{
    grid-template-columns:1fr;
  }
}
@media (max-width: 700px){
  .admin-grid-form{
    padding:18px;
  }
  .admin-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .admin-actions > *{
    width:100%;
  }
  .category-tree-row{
    flex-direction:column;
    align-items:flex-start;
  }
}


/* Premium / New badges on overview cards */
.card-badge-stack{
  position:absolute;
  top:-5px;
  left:16px;
  display:flex;
  flex-wrap:wrap;
  gap:4px;
  z-index:3;
  pointer-events:none;
}

.premium-badge,
.new-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 9px;
  border-radius:999px;
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.01em;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 4px 12px rgba(8,16,38,.14);
}

.premium-badge{
  color:#fff4d0;
  background:linear-gradient(135deg,rgba(94,197,255,.92),rgba(83,122,255,.88));
}

.new-badge{
  color:#effff4;
  background:linear-gradient(135deg,rgba(34,197,94,.86),rgba(22,163,74,.82));
}

.access-card.is-locked strong + .role-pill-row,
.access-card.is-ready strong + .role-pill-row{
  margin-top:14px;
}

.access-card p + .role-pill-row,
.access-card .access-user-row + .role-pill-row{
  margin-top:14px;
}

@media (max-width: 768px){
  .card-badge-stack{
    top:-4px;
    left:10px;
    gap:4px;
  }

  .premium-badge,
  .new-badge{
    padding:4px 8px;
    font-size:.64rem;
  }
}


/* Badge overlap fix on overview cards */
.portal-grid .vehicle-card{
  position:relative;
  overflow:visible;
}

.portal-grid .card-badge-stack{
  top:-4px;
  left:18px;
  z-index:6;
}

.portal-grid .thumb-wrap{
  overflow:hidden;
}

@media (max-width: 768px){
  .portal-grid .card-badge-stack{
    top:-4px;
    left:12px;
  }
}


/* Bottom-right stat badges on overview cards */
.portal-grid .vehicle-card{
  position:relative;
  overflow:visible;
}

.portal-grid .thumb-wrap{
  position:relative;
  display:block;
  overflow:visible;
  padding-bottom:0;
  z-index:5;
}

.portal-grid .thumb{
  display:block;
  border-radius:16px;
  position:relative;
  z-index:1;
}

.portal-grid .thumb-meta{
  position:absolute;
  left:auto;
  right:14px;
  bottom:-13px;
  padding:0;
  background:none;
  pointer-events:none;
  z-index:8;
}

.portal-grid .thumb-stats-badges{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
}

.portal-grid .thumb-stat-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  min-height:26px;
  padding:4px 9px;
  border-radius:999px;
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.01em;
  color:#f4f7fb;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(135deg, rgba(23,27,38,.92), rgba(33,39,54,.88));
  box-shadow:0 8px 18px rgba(5,10,20,.24);
  backdrop-filter:blur(10px);
}

.portal-grid .card-body{
  position:relative;
  z-index:1;
  padding-top:22px;
}

.portal-grid .thumb-meta > div,
.portal-grid .thumb-stats-badges > div{
  max-width:none;
}

@media (max-width: 768px){
  .portal-grid .thumb-wrap{
    padding-bottom:0;
  }

  .portal-grid .thumb-meta{
    right:10px;
    bottom:-11px;
  }

  .portal-grid .thumb-stat-badge{
    min-height:24px;
    padding:4px 8px;
    font-size:.64rem;
  }

  .portal-grid .card-body{
    padding-top:20px;
  }
}

/* Remove outer stats wrapper on card image badges */
.portal-grid .thumb-meta > .thumb-stats-badges{
  padding:0 !important;
  background:none !important;
  border:0 !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
  max-width:none !important;
}

/* Subtle card polish */
.portal-grid .vehicle-card{
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.portal-grid .vehicle-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,122,24,.18);
  box-shadow:0 22px 42px rgba(0,0,0,.26);
}

.portal-grid .vehicle-card:hover .thumb-wrap{
  box-shadow:0 14px 28px rgba(0,0,0,.18);
}


/* Final fix: stat badges may overlap below image without clipping */
.portal-grid .thumb-wrap{
  overflow:visible !important;
  background:transparent !important;
}

.portal-grid .thumb{
  display:block;
  border-radius:16px;
}

.portal-grid .thumb-meta{
  overflow:visible !important;
  bottom:-14px !important;
  z-index:8 !important;
}

.portal-grid .thumb-stats-badges,
.portal-grid .thumb-stat-badge{
  overflow:visible !important;
}


/* Structural fix for floating stat badges */
.portal-grid .card-media-shell{
  position:relative;
  overflow:visible;
  z-index:3;
}
.portal-grid .card-media-shell .thumb-wrap{
  position:relative;
  display:block;
  overflow:hidden !important;
  border-radius:16px;
  z-index:1;
}
.portal-grid .card-media-shell .thumb{
  display:block;
  width:100%;
  border-radius:16px;
}
.portal-grid .thumb-meta.thumb-meta-floating{
  position:absolute !important;
  left:auto !important;
  right:14px !important;
  bottom:-14px !important;
  padding:0 !important;
  background:none !important;
  pointer-events:none !important;
  z-index:30 !important;
  overflow:visible !important;
}
.portal-grid .thumb-meta.thumb-meta-floating .thumb-stats-badges{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  background:none !important;
  border:0 !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
}
.portal-grid .thumb-meta.thumb-meta-floating .thumb-stat-badge{
  position:relative;
  z-index:31;
}
.portal-grid .card-body{
  position:relative;
  z-index:1;
}
@media (max-width: 768px){
  .portal-grid .thumb-meta.thumb-meta-floating{
    right:10px !important;
    bottom:-12px !important;
  }
}


/* Image watermark overlay */
.watermark-frame{
  --wm-pad-x:14px;
  --wm-pad-y:12px;
  --wm-font-size:18px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.watermark-frame::after{
  content:"FiveM Stuff";
  position:absolute;
  right:var(--wm-pad-x);
  bottom:var(--wm-pad-y);
  z-index:4;
  pointer-events:none;
  font-size:var(--wm-font-size);
  font-weight:800;
  line-height:1;
  letter-spacing:-.03em;
  white-space:nowrap;
  font-family:inherit;
  color:transparent;
  background:linear-gradient(90deg, rgba(255,255,255,.72) 0 54%, rgba(255,146,36,.78) 54% 100%);
  -webkit-background-clip:text;
  background-clip:text;
  text-shadow:0 2px 14px rgba(0,0,0,.22);
  opacity:.72;
}
.watermark-frame-card{
  --wm-pad-x:12px;
  --wm-pad-y:10px;
  --wm-font-size:16px;
}
.watermark-frame-main{
  --wm-pad-x:18px;
  --wm-pad-y:16px;
  --wm-font-size:clamp(22px,2.2vw,34px);
}
.watermark-frame-thumb{
  --wm-pad-x:8px;
  --wm-pad-y:7px;
  --wm-font-size:11px;
}
.watermark-frame-lightbox{
  --wm-pad-x:18px;
  --wm-pad-y:16px;
  --wm-font-size:clamp(22px,2.2vw,34px);
}
.gallery-thumb-frame{
  display:block;
  border-radius:16px;
}
.gallery-thumb-frame .gallery-thumb{
  display:block;
}
.thumb-wrap.watermark-frame-card{
  border-radius:22px;
}
.detail-lightbox-trigger.watermark-frame-main,
.lightbox-image-frame.watermark-frame-lightbox{
  border-radius:inherit;
}


.detail-related-section{
  margin-top:48px;
}

.detail-related-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:18px;
}

.detail-related-title{
  margin:0;
  font-size:clamp(1.15rem,1rem + .4vw,1.45rem);
  font-weight:800;
  letter-spacing:-.02em;
}

.detail-related-grid{
  margin-top:0;
}


/* Portal pagination */
.portal-pagination{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:10px;
  margin:26px 0 0;
}
.portal-page-btn,
.portal-page-dots{
  min-width:42px;
  height:42px;
  border-radius:999px;
}
.portal-page-btn{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:var(--text-strong,#fff);
  padding:0 14px;
  font:inherit;
  font-weight:700;
  cursor:pointer;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.portal-page-btn:hover:not(:disabled){
  transform:translateY(-1px);
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.18);
}
.portal-page-btn.is-active{
  background:linear-gradient(135deg,#ff9224,#ffb357);
  border-color:transparent;
  color:#161616;
}
.portal-page-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}
.portal-page-nav{
  min-width:auto;
  padding:0 16px;
}
.portal-page-dots{
  display:grid;
  place-items:center;
  color:rgba(255,255,255,.58);
}
@media (max-width: 640px){
  .portal-pagination{
    gap:8px;
  }
  .portal-page-btn{
    height:38px;
    min-width:38px;
    padding:0 12px;
    font-size:.92rem;
  }
}


.status-badge{display:inline-flex;align-items:center;min-height:32px;padding:6px 12px;border-radius:999px;font-size:.78rem;font-weight:800;border:1px solid rgba(255,255,255,.08);}
.status-badge.is-visible{background:rgba(50,205,120,.14);color:#9ff0be;}
.status-badge.is-hidden{background:rgba(255,255,255,.05);color:#d6dbe5;}
.checkbox-row{display:flex;align-items:center;gap:10px;color:#e6ebf2;font-weight:700;}
.checkbox-row input{width:18px;height:18px;}


/* Embedded watermark now used in uploaded images */
.watermark-frame::after{display:none !important;content:none !important;}

.screenshot-toolbar{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin:14px 0 10px;}
.screenshot-dropzone{border:1px dashed rgba(255,255,255,.18);border-radius:16px;padding:16px 18px;background:rgba(255,255,255,.03);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.screenshot-dropzone.is-dragover{border-color:rgba(255,146,36,.65);background:rgba(255,146,36,.08);}
.screenshot-dropzone-text{display:flex;flex-direction:column;gap:4px;}
.screenshot-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.screenshot-grid{align-items:start;}
.screenshot-item{position:relative;}
.screenshot-remove{margin-top:10px;}
.screenshot-count{font-size:.92rem;color:var(--muted,#9ca3af);}
.visually-hidden{position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap;}


.upload-progress-panel{margin:16px 0;padding:14px 16px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(255,255,255,.03)}
.upload-progress-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.upload-progress-bar{width:100%;height:10px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.upload-progress-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,#ff9224,#ffd166);transition:width .2s ease}
.upload-progress-list{display:grid;gap:8px;margin-top:12px;max-height:220px;overflow:auto}
.upload-progress-item{display:flex;justify-content:space-between;gap:12px;font-size:.92rem;padding:8px 10px;border-radius:12px;background:rgba(255,255,255,.035)}
.upload-progress-name{word-break:break-word}
.upload-progress-status{white-space:nowrap;color:#cfcfcf}
.screenshot-item.is-uploading{opacity:.75}
button.is-disabled{opacity:.65;cursor:not-allowed}
