*,
*::before,
*::after {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background-color: #f5f6f8;
  color: #111827;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a { color: inherit; }

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

/* Full-width containers (admin-only pages can use this) */
.container-fluid {
  max-width: none;
}



/* Admin wide layout helpers (desktop-first) */
.admin-wide-container{
  padding: 0 2rem;
}

.admin-deal-grid{
  display: grid;
  grid-template-columns: 1.35fr 0.65fr;
  gap: 1.25rem;
  align-items: start;
}

/* Two-column deal form layout */
.deal-form-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: start;
}

.deal-form-col{
  min-width: 0;
}

/* Keep preview visible while scrolling on large screens */
.admin-preview-card{
  position: sticky;
  top: 18px;
}

@media (max-width: 1100px){
  .admin-deal-grid{ grid-template-columns: 1fr; }
  .deal-form-grid{ grid-template-columns: 1fr; }
  .admin-preview-card{ position: static; }
}
.compliance-container {
  padding: 0 2rem;
}

.compliance-table-wrap {
  overflow: auto;
  /* Keep the overview usable on large screens */
  max-height: calc(100vh - 420px);
  border: 1px solid rgba(17, 24, 39, 0.08);
  border-radius: 0.9rem;
}

.compliance-table {
  width: 100%;
  min-width: 1200px;
}

/* 0) hidden attribute moet altijd winnen */
[hidden] { display: none !important; }

/* Header */

.site-header {
  background: #050816;
  color: #ffffff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  height: 90px;
  overflow: hidden;
}

.header-inner {
  display: flex;
  align-items: center;
  padding: 0;
  height: 100%;
  gap: 2rem;
}

.logo-link {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  text-decoration: none;
  color: #ffffff;
  font-weight: 700;
  font-size: 1.4rem;
}

.logo-img {
  height: 72px;
  width: auto;
  display: block;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.main-nav a {
  color: #e5e7eb;
  text-decoration: none;
  margin-left: 1rem;
  font-size: 0.95rem;
}

.main-nav a:hover { color: #ffffff; }

.nav-username {
  margin-left: 1rem;
  font-weight: 500;
}

.btn-primary {
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  background: #6366f1;
  color: #ffffff !important;
  font-weight: 500;
  text-decoration: none;
}

.btn-secondary {
  padding: 0.5rem 1rem;
  border-radius: 999px;
  border: 1px solid #d1d5db;
  background: #ffffff;
  color: #111827;
  font-weight: 500;
  text-decoration: none;
}

/* Top actions (burger + auth actions) */
.top-actions{
  display:flex;
  align-items:center;
  gap:12px;
  margin-left: auto;
}


.btn-ghost{
  padding:0.45rem 0.9rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.06);
  color:#e5e7eb;
  text-decoration:none;
  font-weight:500;
}

.btn-ghost:hover{
  background:rgba(255,255,255,0.10);
  color:#ffffff;
}

.knox-burger{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.06);
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  padding:0;
  cursor:pointer;
}

.knox-burger span{
  display:block;
  width:18px;
  height:2px;
  border-radius:99px;
  background:rgba(255,255,255,0.88);
}

.knox-burger:hover{background:rgba(255,255,255,0.10);}

/* Hide burger on desktop */
@media (min-width: 980px){
  .knox-burger{display:none;}
}

/* Main & footer */

.site-main {
  flex: 1 0 auto;
  min-height: 70vh;
  padding: 2rem 0 3rem;
}

/* Logged-in layout: sidebar should start directly under header and run to footer */
body[data-auth="1"] .site-main {
  padding: 0;
  display: flex;
}

body[data-auth="1"] .knox-layout{
  flex: 1 1 auto;
}

.site-footer {
  background: #050816;
  color: #9ca3af;
  padding: 1rem 0;
  margin-top: 2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.footer-inner {
  text-align: center;
  font-size: 0.85rem;
}

/* Hero */

.hero {
  padding: 3rem 0 2rem;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.5fr);
  gap: 2.5rem;
  align-items: center;
}

.hero-eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #6366f1;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.hero-title {
  font-size: clamp(2rem, 3vw, 2.6rem);
  line-height: 1.1;
  margin-bottom: 1rem;
}

.hero-subtitle {
  font-size: 1rem;
  color: #4b5563;
  max-width: 32rem;
  margin-bottom: 1.5rem;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

/* Sections */

.section {
  padding: 2.5rem 0 1.5rem;
}

.section-header {
  display: flex;
  justify-content: flex-start;
  align-items: baseline;
  margin-bottom: 1.5rem;
}

.section-title {
  font-size: 1.4rem;
  font-weight: 600;
}

.section-subtitle {
  font-size: 0.95rem;
  color: #6b7280;
}

/* Creator cards */

.grid {
  display: grid;
  gap: 1.5rem;
}

.grid-3 {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.card {
  background: #ffffff;
  border-radius: 1rem;
  box-shadow: none !important;
  padding: 1rem;
}

.creator-card-banner {
  position: relative;
  height: 120px;
  border-radius: 0.9rem;
  background: linear-gradient(135deg, #6366f1, #ec4899);
  overflow: hidden;
}

.creator-card-avatar {
  position: absolute;
  left: 1rem;
  bottom: -18px;
  width: 56px;
  height: 56px;
  background: #111827;
  border-radius: 40% 60% 60% 40%;
  border: 3px solid #f5f6f8;
}

.creator-card-body { padding-top: 2.2rem; }

.creator-name {
  font-weight: 600;
  margin-bottom: 0.2rem;
}

.creator-meta {
  font-size: 0.85rem;
  color: #6b7280;
}

/* === GLOBAL badge (light, site-wide) === */
.badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 0.75rem;
  padding: 0.1rem 0.55rem;
  background: #eef2ff;
  color: #4f46e5;
  margin-right: 0.35rem;
}

.badge-featured {
  background: #f97316;
  color: #fff;
}

.badge-soft {
  background: rgba(15, 23, 42, 0.7);
  color: #e5e7eb;
}

/* Auth forms */

.auth-wrapper {
  max-width: 420px;
  margin: 0 auto;
}

.card-title {
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 0.25rem;
}

.card-subtitle {
  font-size: 0.9rem;
  color: #6b7280;
  margin-bottom: 1.5rem;
}

.form-group { margin-bottom: 1rem; }

label {
  display: block;
  font-size: 0.9rem;
  margin-bottom: 0.3rem;
}

input[type="text"],
input[type="email"],
input[type="password"] {
  width: 100%;
  padding: 0.55rem 0.65rem;
  border-radius: 0.6rem;
  border: 1px solid #d1d5db;
  font-size: 0.95rem;
}

input:focus {
  outline: none;
  border-color: #6366f1;
  box-shadow: none !important;
}

.form-actions { margin-top: 1.25rem; }

.text-center { text-align: center; }

.text-sm {
  font-size: 0.85rem;
  color: #6b7280;
}

/* Responsive */

@media (max-width: 900px) {
  .hero-grid { grid-template-columns: minmax(0, 1fr); }
}

/* ====== Creator profielpagina ====== */

.creator-hero {
  padding-top: 2.5rem;
  padding-bottom: 1rem;
}

.creator-hero-card {
  background: #ffffff;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: none !important;
}

.creator-hero-banner {
  position: relative;
  height: 220px;
  overflow: hidden;
  background: #020617;
}

.creator-hero-banner::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(to bottom, rgba(15,23,42,0.12), rgba(15,23,42,0.38));
  pointer-events:none;
}

.creator-hero-gradient {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 0% 0%, #6366f1, transparent 55%),
              radial-gradient(circle at 100% 100%, #ec4899, transparent 50%);
  opacity: 0.9;
}

.creator-hero-avatar {
  position: absolute;
  left: 2rem;
  top: 50%;
  transform: translateY(-50%);
  width: 110px;
  height: 110px;
  padding: 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.28);
  z-index: 2;
}

.creator-avatar-shape {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  background: #0f172a;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  border: 3px solid rgba(245, 246, 248, 0.95);
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.35);
  position: relative;
}

.creator-avatar-shape.has-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(15, 23, 42, 0.05), rgba(15, 23, 42, 0.20));
  pointer-events: none;
}

.creator-hero-body {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.3fr);
  gap: 2rem;
  padding: 1.75rem 2rem 1.75rem;
}

.creator-hero-name {
  font-size: 1.8rem;
  margin: 0 0 0.35rem;
}

.creator-hero-meta {
  font-size: 0.9rem;
  color: #6b7280;
  margin: 0 0 0.75rem;
}

.creator-hero-bio {
  font-size: 0.95rem;
  color: #4b5563;
  margin: 0;
}

.creator-hero-side {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.creator-hero-block {
  background: #f9fafb;
  border-radius: 1rem;
  padding: 0.9rem 1rem;
}

.creator-hero-block-title {
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #6b7280;
  margin-bottom: 0.45rem;
}

.creator-hero-small {
  font-size: 0.85rem;
  color: #6b7280;
}

/* Social pills */

.creator-social-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.creator-social-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.25rem 0.7rem;
  font-size: 0.8rem;
  background: #eef2ff;
  color: #4f46e5;
  text-decoration: none;
}

.creator-social-pill:hover { background: #e0e7ff; }

/* Tabs */

.creator-tabs {
  margin-top: 1.25rem;
  display: flex;
  gap: 0.3rem;
  border-bottom: 1px solid #e5e7eb;
}

.creator-tab {
  padding: 0.65rem 1rem;
  font-size: 0.9rem;
  color: #6b7280;
  text-decoration: none;
  border-radius: 0.75rem 0.75rem 0 0;
  border: 1px solid transparent;
  margin-bottom: -1px;
}

.creator-tab-active {
  color: #111827;
  background: #ffffff;
  border-color: #e5e7eb;
  border-bottom-color: #ffffff;
  font-weight: 500;
}

/* Post cards op creator-pagina */

.post-card {
  background: #ffffff;
  border-radius: 1.2rem;
  overflow: hidden;
  box-shadow: none !important;
  display: flex;
  flex-direction: column;
}

.post-card-media {
  position: relative;
  height: 220px;
  background: linear-gradient(135deg, #6366f1, #ec4899);
  overflow: hidden;
}

.post-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15, 23, 42, 0.55), rgba(15, 23, 42, 0.15));
}

.post-card-labels {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  display: flex;
  gap: 0.35rem;
}

.post-card-text {
  position: absolute;
  left: 0.9rem;
  right: 0.9rem;
  bottom: 0.9rem;
}

.post-card-title {
  font-size: 1.05rem;
  color: #f9fafb;
  margin: 0 0 0.25rem;
}

.post-card-excerpt {
  font-size: 0.85rem;
  color: #e5e7eb;
  margin: 0;
}

.post-card-footer {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding: 0.8rem 1rem 0.9rem;
}

.post-card-meta {
  font-size: 0.85rem;
  color: #6b7280;
}

.post-card-btn { font-size: 0.85rem; }

/* Responsive creator */

@media (max-width: 900px) {
  .creator-hero-body {
    grid-template-columns: minmax(0, 1fr);
    padding: 1.5rem 1.5rem 1.5rem;
  }

  .creator-hero-avatar {
    left: 1.25rem;
    top: 50%;
    transform: translateY(-50%);
    width: 86px;
    height: 86px;
    padding: 5px;
  }
}

/* ====== Simple table layout in cards ====== */

.table {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.table-row {
  display: grid;
  grid-template-columns: minmax(0, 2.4fr) 0.8fr 0.8fr 1.4fr;
  gap: 0.75rem;
  padding: 0.55rem 0.25rem;
  align-items: center;
}

.table-header {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #6b7280;
  border-bottom: 1px solid #e5e7eb;
  margin-bottom: 0.25rem;
}

.table-row:not(.table-header) {
  font-size: 0.9rem;
  border-bottom: 1px solid #f3f4f6;
}

.table-meta {
  font-size: 0.8rem;
  color: #9ca3af;
}

.table-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.6rem;
  font-size: 0.83rem;
}

.table-link {
  text-decoration: none;
  color: #4f46e5;
}

.table-link:hover { text-decoration: underline; }

.table-link-danger { color: #b91c1c; }

/* ====== Likes & reacties op post pagina ====== */

.post-like-row {
  margin-top: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.post-like-form {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

 .like-button {
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  color: #e5e7eb;
  padding: 0.35rem 0.95rem;
  font-size: 0.9rem;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.05s ease;
}
.like-button:hover { background: rgba(255,255,255,0.12); }
.like-button:active { transform: translateY(1px); }


.like-button.liked {
  border-color: rgba(236,72,153,0.85);
  background: rgba(236,72,153,0.16);
  color: #fce7f3;
}


.like-count {
  font-size: 0.9rem;
  color: #6b7280;
}

.like-login-hint {
  font-size: 0.85rem;
  color: #4f46e5;
  text-decoration: none;
}

/* === Post emoji reactions (PNG/WebP in /assets/reactions) === */
.post-reactions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.15rem;
  align-items: center;
}

.reaction-chip-form,
.reaction-emoji-form {
  margin: 0;
}

.reaction-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  color: #e5e7eb;
  padding: 0.25rem 0.6rem;
  font-size: 0.85rem;
  line-height: 1;
}


button.reaction-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  color: #e5e7eb;
  padding: 0.25rem 0.6rem;
  font-size: 0.85rem;
  line-height: 1;
}


.reaction-chip.mine {
  border-color: rgba(236,72,153,0.85);
  background: rgba(236,72,153,0.16);
}


.reaction-chip img {
  width: 20px;
  height: 20px;
  display: block;
}


.reaction-count {
  color: #6b7280;
  font-weight: 500;
  font-size: 0.8rem;
}

.reaction-picker {
  margin-left: 0.35rem;
}

.reaction-picker > summary.reaction-add {
  list-style: none;
  cursor: pointer;
  user-select: none;
  border-radius: 999px;
  border: 1px dashed rgba(255,255,255,0.22);
  padding: 0.25rem 0.7rem;
  font-size: 0.85rem;
  color: #e5e7eb;
  background: rgba(255,255,255,0.06);
}
.reaction-picker > summary.reaction-add:hover { background: rgba(255,255,255,0.10); }


.reaction-picker > summary::-webkit-details-marker {
  display: none;
}

.reaction-grid {
  margin-top: 0.5rem;
  padding: 0.6rem;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 12px;
  background: rgba(0,0,0,0.22);
  backdrop-filter: blur(10px);
}


.reaction-emoji-btn {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  cursor: pointer;
}
.reaction-emoji-btn:hover { background: rgba(255,255,255,0.10); }


.reaction-emoji-btn:hover {
  border-color: #d1d5db;
  background: #f9fafb;
}

/* Stap 4: smooth hover zoom op het plaatje */
.reaction-emoji-btn img {
  width:52px;
  height: 79px;
  display: block;
  transition: transform 0.12s ease;
}

.reaction-emoji-btn:hover img {
  transform: scale(1.15);
}




.like-login-hint:hover { text-decoration: underline; }

/* Reacties */

.comment-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.comment-item {
  padding: 0.65rem 0.6rem;
  border-bottom: 1px solid #e5e7eb;
}

/* ====== Trending posts op homepage ====== */

.trending-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.trending-item {
  padding: 0.7rem 0.5rem;
  border-bottom: 1px solid #e5e7eb;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
}

.trending-title {
  font-size: 0.98rem;
  font-weight: 600;
  color: #111827;
  text-decoration: none;
}

.trending-title:hover { text-decoration: underline; }

.trending-meta {
  font-size: 0.85rem;
  color: #6b7280;
  margin-top: 0.1rem;
}

.trending-likes {
  display: flex;
  align-items: baseline;
  gap: 0.25rem;
  font-size: 0.9rem;
}

.trending-like-count { font-weight: 700; }

.trending-like-label {
  font-size: 0.8rem;
  color: #6b7280;
}

@media (max-width: 700px) {
  .trending-item { align-items: flex-start; }
}

/* ====== Partners / bedrijven pagina ====== */

.partners-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1.2fr);
  gap: 2rem;
  align-items: center;
}

.partners-stats {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.partners-stats-inner {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  background: #020617;
  border-radius: 1.4rem;
  padding: 1rem 1.5rem;
}

.partners-stat-label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #9ca3af;
}

.partners-stat-value {
  font-size: 1.4rem;
  font-weight: 600;
  color: #f9fafb;
  margin-top: 0.2rem;
}

.partners-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.3rem;
}

.partners-step {
  background: #ffffff;
  border-radius: 1.2rem;
  padding: 1rem 1rem 1.1rem;
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.08);
}

.partners-step-number {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #4f46e5;
  color: #f9fafb;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  margin-bottom: 0.5rem;
}

.partners-step-title {
  font-size: 1rem;
  margin: 0 0 0.25rem;
}

.partners-step-text {
  font-size: 0.9rem;
  color: #4b5563;
  margin: 0;
}

.partners-features .card p {
  font-size: 0.9rem;
  color: #4b5563;
}

@media (max-width: 900px) {
  .partners-hero { grid-template-columns: minmax(0, 1fr); }
  .partners-stats-inner { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .partners-steps { grid-template-columns: minmax(0, 1fr); }
}

@media (max-width: 600px) {
  .partners-stats-inner { grid-template-columns: minmax(0, 1fr); }
}

/* ===== Fix voor admin statistiek-cards ===== */

.admin-stats .card {
  background: #ffffff !important;
  color: #111827 !important;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
  border: 1px solid #e5e7eb;
}

.admin-stats .partners-stat-label { color: #6b7280 !important; }

.admin-stats .partners-stat-value {
  color: #111827 !important;
  font-weight: 700;
}

/* ===== Admin dashboard layout ===== */

.admin-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  margin-bottom: 1.75rem;
}

.admin-stat-card {
  flex: 1 1 140px;
  padding: 0.8rem 0.9rem;
}

.admin-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.5fr);
  gap: 1.5rem;
}

@media (max-width: 900px) {
  .admin-main-grid { grid-template-columns: minmax(0, 1fr); }
}


/* ===== Admin dashboard tabs ===== */
.admin-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
  padding:.35rem;
  border:1px solid var(--knox-card-border);
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.02));
  margin-top:1rem;
}

.admin-tab-btn{
  appearance:none;
  border:0;
  background:transparent;
  color:var(--knox-text);
  opacity:.78;
  font-weight:700;
  font-size:13px;
  padding:.5rem .9rem;
  border-radius:999px;
  cursor:pointer;
  transition:opacity .15s ease, transform .15s ease, background .15s ease;
}

.admin-tab-btn:hover{ opacity:1; transform:translateY(-1px); }

.admin-tab-btn.active{
  opacity:1;
  background:var(--knox-accent);
  color:#ffffff;
}

.admin-tab-panel{display:block;}
.admin-tab-panel.is-hidden{display:none;}

/* =========================================================
   ADMIN (DARK MODE) – cards dezelfde kleur als tabbalk
   Theme trigger in Knoxlink: body.knox-theme--dark
   (ook compatibel met body[data-theme="dark"] / body.dark)
   ========================================================= */

body.knox-dark .admin-tabs,
body.knox-theme--dark .admin-tabs,
body[data-theme="dark"] .admin-tabs,
body.dark .admin-tabs{
  /* Zorg dat tabbalk en cards exact dezelfde surface hebben */
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.02));
}

/* Alle admin cards donker (zelfde surface als tabs) + witte tekst */
body.knox-dark .admin-stats .card,
body.knox-dark .admin-main-grid .card,
body.knox-dark .admin-tab-panel .card,
body.knox-theme--dark .admin-stats .card,
body.knox-theme--dark .admin-main-grid .card,
body.knox-theme--dark .admin-tab-panel .card,
body[data-theme="dark"] .admin-stats .card,
body[data-theme="dark"] .admin-main-grid .card,
body[data-theme="dark"] .admin-tab-panel .card,
body.dark .admin-stats .card,
body.dark .admin-main-grid .card,
body.dark .admin-tab-panel .card{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.02)) !important;
  border: 1px solid var(--knox-card-border) !important;
  color: #ffffff !important;
  box-shadow: none !important;
}

/* Stat labels/values altijd wit */
body.knox-dark .admin-stats .partners-stat-label,
body.knox-theme--dark .admin-stats .partners-stat-label,
body[data-theme="dark"] .admin-stats .partners-stat-label,
body.dark .admin-stats .partners-stat-label{
  color: rgba(255,255,255,.82) !important;
}

body.knox-dark .admin-stats .partners-stat-value,
body.knox-theme--dark .admin-stats .partners-stat-value,
body[data-theme="dark"] .admin-stats .partners-stat-value,
body.dark .admin-stats .partners-stat-value{
  color: #ffffff !important;
}

/* Alle tekst in admin cards wit (ook headings, table, links) */
body.knox-dark .admin-stats .card *,
body.knox-dark .admin-main-grid .card *,
body.knox-dark .admin-tab-panel .card *,
body.knox-theme--dark .admin-stats .card *,
body.knox-theme--dark .admin-main-grid .card *,
body.knox-theme--dark .admin-tab-panel .card *,
body[data-theme="dark"] .admin-stats .card *,
body[data-theme="dark"] .admin-main-grid .card *,
body[data-theme="dark"] .admin-tab-panel .card *,
body.dark .admin-stats .card *,
body.dark .admin-main-grid .card *,
body.dark .admin-tab-panel .card *{
  color: #ffffff;
}

/* Subtle: muted tekst iets zachter */
body.knox-dark .admin-stats .card .table-meta,
body.knox-dark .admin-main-grid .card .table-meta,
body.knox-dark .admin-tab-panel .card .table-meta,
body.knox-theme--dark .admin-stats .card .table-meta,
body.knox-theme--dark .admin-main-grid .card .table-meta,
body.knox-theme--dark .admin-tab-panel .card .table-meta,
body[data-theme="dark"] .admin-stats .card .table-meta,
body[data-theme="dark"] .admin-main-grid .card .table-meta,
body[data-theme="dark"] .admin-tab-panel .card .table-meta,
body.dark .admin-stats .card .table-meta,
body.dark .admin-main-grid .card .table-meta,
body.dark .admin-tab-panel .card .table-meta{
  color: rgba(255,255,255,.72) !important;
}

/* Admin tabs: tekst wit, active blijft accent */
body.knox-dark .admin-tab-btn,
body.knox-theme--dark .admin-tab-btn,
body[data-theme="dark"] .admin-tab-btn,
body.dark .admin-tab-btn{
  color: #ffffff !important;
  opacity: .80;
}

body.knox-dark .admin-tab-btn.active,
body.knox-theme--dark .admin-tab-btn.active,
body[data-theme="dark"] .admin-tab-btn.active,
body.dark .admin-tab-btn.active{
  color: #ffffff !important;
}

/* =========================================================
   ADMIN (DARK MODE) – buttons & form controls
   - Alle admin-knoppen paars
   - Inputs/selects/textarea donkergrijs (zoals in "Nieuw bericht")
   ========================================================= */

/* Tabs ook een paarse "chip" look (inactive), active blijft accent */
body.knox-dark .admin-tab-btn,
body.knox-theme--dark .admin-tab-btn,
body[data-theme="dark"] .admin-tab-btn,
body.dark .admin-tab-btn{
  background: rgba(139, 92, 246, .10);
  border: 1px solid rgba(139, 92, 246, .25);
}

body.knox-dark .admin-tab-btn.active,
body.knox-theme--dark .admin-tab-btn.active,
body[data-theme="dark"] .admin-tab-btn.active,
body.dark .admin-tab-btn.active{
  border-color: transparent;
}

/* Admin knoppen paars (ook de pill-links die nu wit zijn: btn-secondary) */
body.knox-dark .admin-stats .btn-secondary,
body.knox-dark .admin-main-grid .btn-secondary,
body.knox-dark .admin-tab-panel .btn-secondary,
body.knox-theme--dark .admin-stats .btn-secondary,
body.knox-theme--dark .admin-main-grid .btn-secondary,
body.knox-theme--dark .admin-tab-panel .btn-secondary,
body[data-theme="dark"] .admin-stats .btn-secondary,
body[data-theme="dark"] .admin-main-grid .btn-secondary,
body[data-theme="dark"] .admin-tab-panel .btn-secondary,
body.dark .admin-stats .btn-secondary,
body.dark .admin-main-grid .btn-secondary,
body.dark .admin-tab-panel .btn-secondary{
  background: var(--knox-accent) !important;
  border-color: transparent !important;
  color: #ffffff !important;
}

body.knox-dark .admin-stats .btn-secondary:hover,
body.knox-dark .admin-main-grid .btn-secondary:hover,
body.knox-dark .admin-tab-panel .btn-secondary:hover,
body.knox-theme--dark .admin-stats .btn-secondary:hover,
body.knox-theme--dark .admin-main-grid .btn-secondary:hover,
body.knox-theme--dark .admin-tab-panel .btn-secondary:hover,
body[data-theme="dark"] .admin-stats .btn-secondary:hover,
body[data-theme="dark"] .admin-main-grid .btn-secondary:hover,
body[data-theme="dark"] .admin-tab-panel .btn-secondary:hover,
body.dark .admin-stats .btn-secondary:hover,
body.dark .admin-main-grid .btn-secondary:hover,
body.dark .admin-tab-panel .btn-secondary:hover{
  filter: brightness(1.07);
}

/* Form controls donkergrijs + witte tekst */
body.knox-dark .admin-stats input,
body.knox-dark .admin-stats select,
body.knox-dark .admin-stats textarea,
body.knox-dark .admin-main-grid input,
body.knox-dark .admin-main-grid select,
body.knox-dark .admin-main-grid textarea,
body.knox-dark .admin-tab-panel input,
body.knox-dark .admin-tab-panel select,
body.knox-dark .admin-tab-panel textarea,
body.knox-theme--dark .admin-stats input,
body.knox-theme--dark .admin-stats select,
body.knox-theme--dark .admin-stats textarea,
body.knox-theme--dark .admin-main-grid input,
body.knox-theme--dark .admin-main-grid select,
body.knox-theme--dark .admin-main-grid textarea,
body.knox-theme--dark .admin-tab-panel input,
body.knox-theme--dark .admin-tab-panel select,
body.knox-theme--dark .admin-tab-panel textarea,
body[data-theme="dark"] .admin-stats input,
body[data-theme="dark"] .admin-stats select,
body[data-theme="dark"] .admin-stats textarea,
body[data-theme="dark"] .admin-main-grid input,
body[data-theme="dark"] .admin-main-grid select,
body[data-theme="dark"] .admin-main-grid textarea,
body[data-theme="dark"] .admin-tab-panel input,
body[data-theme="dark"] .admin-tab-panel select,
body[data-theme="dark"] .admin-tab-panel textarea,
body.dark .admin-stats input,
body.dark .admin-stats select,
body.dark .admin-stats textarea,
body.dark .admin-main-grid input,
body.dark .admin-main-grid select,
body.dark .admin-main-grid textarea,
body.dark .admin-tab-panel input,
body.dark .admin-tab-panel select,
body.dark .admin-tab-panel textarea{
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  color: #ffffff !important;
}

/* Placeholder kleur */
body.knox-dark .admin-stats input::placeholder,
body.knox-dark .admin-stats textarea::placeholder,
body.knox-dark .admin-main-grid input::placeholder,
body.knox-dark .admin-main-grid textarea::placeholder,
body.knox-dark .admin-tab-panel input::placeholder,
body.knox-dark .admin-tab-panel textarea::placeholder,
body.knox-theme--dark .admin-stats input::placeholder,
body.knox-theme--dark .admin-stats textarea::placeholder,
body.knox-theme--dark .admin-main-grid input::placeholder,
body.knox-theme--dark .admin-main-grid textarea::placeholder,
body.knox-theme--dark .admin-tab-panel input::placeholder,
body.knox-theme--dark .admin-tab-panel textarea::placeholder,
body[data-theme="dark"] .admin-stats input::placeholder,
body[data-theme="dark"] .admin-stats textarea::placeholder,
body[data-theme="dark"] .admin-main-grid input::placeholder,
body[data-theme="dark"] .admin-main-grid textarea::placeholder,
body[data-theme="dark"] .admin-tab-panel input::placeholder,
body[data-theme="dark"] .admin-tab-panel textarea::placeholder,
body.dark .admin-stats input::placeholder,
body.dark .admin-stats textarea::placeholder,
body.dark .admin-main-grid input::placeholder,
body.dark .admin-main-grid textarea::placeholder,
body.dark .admin-tab-panel input::placeholder,
body.dark .admin-tab-panel textarea::placeholder{
  color: rgba(255,255,255,.55) !important;
}

/* Checkbox/radio accentkleur (waar supported) */
body.knox-dark .admin-tab-panel input[type="checkbox"],
body.knox-dark .admin-tab-panel input[type="radio"],
body.knox-theme--dark .admin-tab-panel input[type="checkbox"],
body.knox-theme--dark .admin-tab-panel input[type="radio"],
body[data-theme="dark"] .admin-tab-panel input[type="checkbox"],
body[data-theme="dark"] .admin-tab-panel input[type="radio"],
body.dark .admin-tab-panel input[type="checkbox"],
body.dark .admin-tab-panel input[type="radio"]{
  accent-color: var(--knox-accent);
}

/* ===== Deals / affiliate cards ===== */

.deals-wrapper { margin-top: 1.25rem; }

.deals-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

/* ===== Deal cards (compact / casino-style layout in Knoxlink look) ===== */
.deal-card--compact{
  background: linear-gradient(180deg, #0b1020 0%, #070a14 100%);
  border: 1px solid rgba(99, 102, 241, 0.35);
  border-radius: 1.2rem;
  overflow: hidden;
  box-shadow: none !important;
  display: flex;
  flex-direction: column;
  min-height: 320px;
}

.deal-card-top{
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.75rem;
  padding: 0.65rem 0.7rem 0;
}

.deal-badges{
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

/* === BADGE (DARK) alleen in deal cards === */
.deal-card--compact .badge{
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 0.55rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.92);
  margin-right: 0;
}

.deal-card--compact .badge--amber{
  background: rgba(245, 158, 11, 0.18);
  border-color: rgba(245, 158, 11, 0.35);
  color: #fbbf24;
}
.deal-card--compact .badge--purple{
  background: rgba(168, 85, 247, 0.16);
  border-color: rgba(168, 85, 247, 0.35);
  color: #c084fc;
}
.deal-card--compact .badge--slate{
  background: rgba(148, 163, 184, 0.12);
  border-color: rgba(148, 163, 184, 0.28);
  color: #cbd5e1;
}

.deal-info{
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.9);
  font-weight: 800;
  cursor: pointer;
  position: relative;
}

.deal-info:hover{
  background: rgba(255,255,255,0.10);
}

.deal-info[data-tooltip]:hover::after{
  content: attr(data-tooltip);
  position: absolute;
  right: 0;
  top: 36px;
  width: min(260px, 70vw);
  padding: 0.6rem 0.7rem;
  border-radius: 0.85rem;
  background: rgba(2, 6, 23, 0.96);
  border: 1px solid rgba(99, 102, 241, 0.28);
  color: rgba(255,255,255,0.92);
  font-size: 0.82rem;
  line-height: 1.25rem;
  box-shadow: 0 16px 40px rgba(0,0,0,0.45);
  z-index: 20;
}

.deal-logo-wrap{
  margin: 0.65rem 0.7rem 0;
  height: 84px;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,0.10);
  background: radial-gradient(120% 140% at 50% 0%, rgba(99,102,241,0.22) 0%, rgba(255,255,255,0.04) 52%, rgba(0,0,0,0.10) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.deal-logo{
  max-width: 86%;
  max-height: 66px;
  object-fit: contain;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,0.45));
}

.deal-logo-fallback{
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.10);
}

.deal-content{
  padding: 0.7rem 0.85rem 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  flex: 1;
}

.deal-card--compact .deal-partner{
  color: rgba(255,255,255,0.72);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
}

.deal-card--compact .deal-title{
  color: rgba(255,255,255,0.96);
  font-size: 1.05rem;
  margin: 0;
  line-height: 1.2rem;
}

.deal-cta{
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 800;
  color: #0b1020;
  background: linear-gradient(90deg, #fbbf24, #f59e0b);
  border: 1px solid rgba(245, 158, 11, 0.45);
  box-shadow: 0 14px 26px rgba(245, 158, 11, 0.18);
}

.deal-cta:hover{
  filter: brightness(1.03);
  transform: translateY(-1px);
}

.deal-footnote{
  margin-top: 0.45rem;
  text-align: center;
  font-size: 0.72rem;
  color: rgba(255,255,255,0.55);
}

@media (max-width: 900px) {
  .deals-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .deals-grid { grid-template-columns: minmax(0, 1fr); }
}

/* ====== Live status styling ====== */

.creator-hero-live {
  margin-top: 0.4rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.6rem;
  align-items: center;
}

.badge-live {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.15rem 0.7rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  background: rgba(34, 197, 94, 0.12);
  color: #065f46;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.badge-live-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.28);
}

.creator-hero-live-title {
  font-size: 0.82rem;
  color: #4b5563;
}

.creator-live-block {
  border: 1px solid rgba(34, 197, 94, 0.18);
  background: linear-gradient(135deg, rgba(240, 253, 250, 0.9), #ffffff);
}

.live-indicator,
.offline-indicator {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
}

.live-dot {
  width: 11px;
  height: 11px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 6px rgba(34, 197, 94, 0.25);
  margin-top: 0.15rem;
}

.live-text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.live-label {
  font-size: 0.86rem;
  color: #065f46;
}

.live-title {
  font-size: 0.8rem;
  color: #047857;
}

.offline-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #9ca3af;
  box-shadow: 0 0 0 4px rgba(156, 163, 175, 0.25);
  margin-top: 0.2rem;
}

.offline-label {
  font-size: 0.86rem;
  color: #4b5563;
  font-weight: 500;
}

.offline-sub {
  font-size: 0.8rem;
  color: #9ca3af;
  margin-top: 0.1rem;
}

/* ====== Home: Nu live blok ====== */

.live-home-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.25rem;
}

.live-home-card {
  background: #ffffff;
  border-radius: 1.2rem;
  padding: 1rem 1rem 1.1rem;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.12);
  border: 1px solid rgba(226, 232, 240, 0.9);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.live-home-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.25rem;
}

.live-home-avatar {
  width: 42px;
  height: 42px;
  border-radius: 40% 60% 60% 40%;
  background: #0f172a;
  border: 3px solid #e5e7eb;
}

.live-home-name {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
}

.live-home-title {
  font-size: 0.88rem;
  color: #111827;
  margin: 0.15rem 0 0;
}

.live-home-bio {
  font-size: 0.85rem;
  color: #6b7280;
  margin: 0.25rem 0 0.4rem;
}

.live-home-btn {
  align-self: flex-start;
  margin-top: 0.25rem;
  font-size: 0.85rem;
}

/* ====== Algemene profielpagina ====== */

.profile-card {
  max-width: 640px;
  margin: 0 auto;
}

.profile-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.profile-avatar {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: #111827;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #f9fafb;
  font-size: 1.4rem;
  font-weight: 700;
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.35);
  overflow: hidden;
}

.profile-avatar-initial { transform: translateY(1px); }

.profile-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 999px;
}

.profile-header-text {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.profile-username {
  font-size: 1.1rem;
  font-weight: 600;
}

.profile-role {
  font-size: 0.85rem;
  color: #4b5563;
}

.profile-meta {
  font-size: 0.8rem;
  color: #9ca3af;
}

.profile-form { margin-top: 0.75rem; }

.profile-success {
  font-size: 0.9rem;
  color: #16a34a;
  margin-bottom: 0.5rem;
}

.profile-errors {
  margin: 0 0 0.75rem;
  padding-left: 1.1rem;
  font-size: 0.85rem;
  color: #b91c1c;
}

.profile-help {
  font-size: 0.8rem;
  color: #6b7280;
  margin-top: 0.25rem;
}

.profile-extra {
  margin-top: 1.25rem;
  border-top: 1px solid #e5e7eb;
  padding-top: 0.75rem;
  font-size: 0.9rem;
}

/* ====== Avatars bij reacties ====== */

.comment-item {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  padding: 0.65rem 0.6rem;
  border-bottom: 1px solid #e5e7eb;
}

.comment-avatar {
  width: 32px;
  height: 96px;
  border-radius: 999px;
  background: #111827;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #f9fafb;
  font-size: 0.85rem;
  font-weight: 600;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.3);
  flex-shrink: 0;
  overflow: hidden;
}

.comment-avatar-initial { transform: translateY(0.5px); }

.comment-avatar-img {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  object-fit: cover;
}

.comment-content { flex: 1; }

/* ====== Post gallery / carousel ====== */

.post-gallery {
  margin: 0.75rem 0 1.25rem;
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
  background: #020617;
}

.post-gallery-inner {
  position: relative;
  min-height: 220px;
}

.post-gallery-slide { display: none; }

.post-gallery-img {
  width: 100%;
  padding-top: 56.25%;
  background-size: cover;
  background-position: center;
}

.gallery-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: rgba(15, 23, 42, 0.6);
  color: #f9fafb;
  width: 32px;
  height: 96px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gallery-prev { left: 0.75rem; }
.gallery-next { right: 0.75rem; }

.gallery-nav:hover { background: rgba(15, 23, 42, 0.9); }

.post-gallery-indicator {
  position: absolute;
  right: 0.75rem;
  bottom: 0.6rem;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.8);
  color: #e5e7eb;
  font-size: 0.75rem;
}

/* =========================================================
   GLOBAL AVATAR STYLE (premium, consistent over the whole site)
   ========================================================= */

.creator-card-avatar,
.live-home-avatar,
.profile-avatar,
.comment-avatar,
.creator-avatar-shape {
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  border-radius: 999px;
  position: relative;
  border: 3px solid rgba(245, 246, 248, 0.95);
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.30);
}

.creator-card-avatar.has-image::after,
.live-home-avatar.has-image::after,
.creator-avatar-shape.has-image::after {
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(to bottom, rgba(15,23,42,0.05), rgba(15,23,42,0.20));
  pointer-events:none;
}

.creator-card-initial,
.profile-avatar-initial,
.comment-avatar-initial {
  line-height: 1;
  transform: translateY(0.5px);
}

/* Optional glass frame */
.avatar-frame {
  padding: 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.22);
}

/* =========================================================
   CREATOR: Featured + Deals naast elkaar
   ========================================================= */

.creator-featured-wrap{
  margin-top: 1.2rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
  gap: 1rem;
  align-items: stretch;
}

@media (max-width: 900px){
  .creator-featured-wrap{
    grid-template-columns: 1fr;
  }
}

.creator-featured-card{
  background: #ffffff;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.12);
  border: 1px solid rgba(226, 232, 240, 0.9);
  width: 100%;
  height: 100%;
  display:flex;
  flex-direction:column;
}

.creator-featured-media{
  position: relative;
  height: 165px;
  background: linear-gradient(135deg, #6366f1, #ec4899);
  overflow: hidden;
  flex: 1;
  min-height: 165px;
}

.creator-featured-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15, 23, 42, 0.60), rgba(15, 23, 42, 0.12));
}

.creator-featured-badges{
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  display: flex;
  gap: 0.4rem;
  z-index: 2;
}

.creator-featured-text{
  position: absolute;
  left: 0.9rem;
  right: 0.9rem;
  bottom: 0.85rem;
  z-index: 2;
  color: #f9fafb;
}

.creator-featured-title{
  margin: 0 0 0.25rem;
  font-size: 1.1rem;
  line-height: 1.15;
}

.creator-featured-excerpt{
  margin: 0;
  font-size: 0.85rem;
  color: #e5e7eb;
  opacity: 0.95;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.creator-featured-footer{
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.8rem;
  padding: 0.75rem 0.9rem 0.85rem;
  flex-wrap: wrap;
}

.creator-featured-meta{
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.82rem;
  color: #6b7280;
}

.creator-featured-actions{
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
}

/* Desktop: aanbiedingen naast elkaar */
.offers-mini-carousel{
  height: 100%;
  display: flex;
  gap: 0.65rem;
  align-items: stretch;
  flex-wrap: wrap;
}

.offer-mini-card{
  flex: 1 1 calc(25% - 0.65rem);
  max-width: calc(25% - 0.65rem);
  height: 100%;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

/* Mobiel gedrag */
@media (max-width: 900px){
  .creator-featured-media{
    height: 175px;
  }

  .offers-mini-carousel{
    display:flex;
    overflow-x:auto;
    gap:0.65rem;
    scroll-snap-type:x mandatory;
    padding-bottom:0.25rem;
    flex-wrap: nowrap;
  }

  .offer-mini-card{
    min-width: 210px;
    max-width: 210px;
    scroll-snap-align:start;
  }
}

/* =========================================================
   GOLDEN MINI CARD (offer-mini-card--golden)
   ========================================================= */

.offer-mini-card.offer-mini-card--golden{
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.10);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: none !important;
  display:flex;
  flex-direction:column;
  min-height: 220px;
}

.offer-mini-card--golden .om-head{
  height: 76px;
  background: linear-gradient(135deg, rgba(99,102,241,1) 0%, rgba(168,85,247,1) 55%, rgba(236,72,153,1) 100%);
  background-size: cover;
  background-position: center;
  position: relative;
}

.offer-mini-card--golden .om-head-fade{
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0.06) 0%, rgba(0,0,0,0.02) 55%, rgba(0,0,0,0.00) 100%);
}

.offer-mini-card--golden .om-head-top{
  position:absolute;
  top:10px;
  left:10px;
  right:10px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  z-index:2;
}

.offer-mini-card--golden .om-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.offer-mini-card--golden .om-tag{
  height: 22px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  color:#0f172a;
}

.offer-mini-card--golden .om-tag--primary{
  background: rgba(255,255,255,0.96);
  border-color: rgba(99,102,241,0.22);
  color:#4f46e5;
}

.offer-mini-card--golden .om-info{
  width:24px;
  height:24px;
  border-radius:999px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(255,255,255,0.92);
  color: rgba(15,23,42,0.80);
  font-weight:900;
  cursor:pointer;
  position: relative;
  box-shadow: none !important;
}

.offer-mini-card--golden .om-info[data-tooltip]:hover::after{
  content: attr(data-tooltip);
  position: absolute;
  right: 0;
  top: 34px;
  width: min(260px, 70vw);
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(15, 23, 42, 0.96);
  border: 1px solid rgba(99, 102, 241, 0.25);
  color: rgba(255,255,255,0.95);
  font-size: 13px;
  line-height: 1.35;
  box-shadow: none !important;
  z-index: 20;
}

.offer-mini-card--golden .om-body{
  padding: 12px 12px 14px;
  display:flex;
  flex-direction:column;
  gap: 6px;
  flex: 1;
}

.offer-mini-card--golden .om-partner{
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(15, 23, 42, 0.52);
}

.offer-mini-card--golden .om-title{
  font-size: 15px;
  font-weight: 950;
  line-height: 1.15;
  color: #0f172a;
  margin-bottom: 4px;
}

.offer-mini-card--golden .om-highlight{
  display:flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(99,102,241,0.05);
  border: 1px solid rgba(99,102,241,0.10);
  color: rgba(15,23,42,0.86);
  font-size: 13px;
  font-weight: 700;
}

.offer-mini-card--golden .om-highlight-dot{
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(99,102,241,1);
  box-shadow: none !important;
}

.offer-mini-card--golden .om-footer{
  margin-top: auto;
  padding-top: 8px;
}

.offer-mini-card--golden .om-cta{
  width: 100%;
  height: 40px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight: 900;
  color:#fff;
  background: linear-gradient(90deg, rgba(99,102,241,1), rgba(168,85,247,1));
  box-shadow: none !important;
}

.offer-mini-card--golden .om-cta:hover{
  transform: translateY(-1px);
  filter: brightness(1.03);
}

/* =========================================================
   INLINE deals panel (tussen mini-deals en tabs)
   ========================================================= */

.creator-inline-deals{
  margin-top: 14px;
  margin-bottom: 14px;
}

.inline-deals-head{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

#inlineDealsSearch.deals-input{
  width: min(420px, 70vw);
  height: 42px;
}

.inline-deals-panel{
  overflow: hidden;
  transition: max-height .35s ease;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  margin-top: 10px;
}

.inline-deals-controls{
  display:flex;
  align-items:flex-end;
  gap:12px;
  flex:0 0 auto;
  min-width: 220px;
  padding: 12px 12px 0;
}

.inline-deals-body{
  padding: 12px;
}

.deals-empty{
  margin-top: 1rem;
  padding: 0.9rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.05);
  color: rgba(255,255,255,0.86);
}

/* =========================================================
   FASE 2: Subscribe Modal UI
   ========================================================= */

.knox-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: 9999;
}

.knox-modal-overlay.is-open { display: flex; }

.knox-modal {
  width: min(860px, 100%);
  /* Match Knoxlink dark/glass card styling */
  background: rgba(2, 6, 23, 0.92);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  backdrop-filter: blur(12px);
  color: rgba(255,255,255,0.92);
  overflow: hidden;
}

.knox-modal-header {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  padding: 18px 18px 12px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}

.knox-modal-close {
  border: 0;
  background: transparent;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 10px;
  color: rgba(255,255,255,0.92);
}

.knox-modal-close:hover { background: rgba(255,255,255,0.08); }

.knox-modal-body { padding: 16px 18px 18px 18px; }

.knox-tier-grid {
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 900px) {
  .knox-tier-grid { grid-template-columns: 1fr; }
}

.knox-tier-card {
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  padding: 14px;
  background: rgba(255,255,255,0.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

.knox-tier-top {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.knox-tier-name {
  font-weight: 700;
  font-size: 16px;
  color: rgba(255,255,255,0.96);
}

.knox-tier-price {
  margin-top: 6px;
  font-weight: 800;
  font-size: 20px;
  color: rgba(255,255,255,0.96);
}

.knox-tier-per {
  font-weight: 500;
  opacity: .65;
  font-size: 13px;
  color: rgba(255,255,255,0.70);
}

.knox-pill {
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(168, 85, 247, 0.18);
  border: 1px solid rgba(168, 85, 247, 0.35);
  color: #c084fc;
  font-weight: 700;
}

.knox-tier-benefits {
  margin: 10px 0 14px 0;
  padding-left: 18px;
  color: rgba(255,255,255,0.86);
}

.knox-tier-benefits li { margin: 6px 0; }

.knox-hr {
  border: 0;
  height: 1px;
  background: rgba(255,255,255,0.10);
  margin: 16px 0;
}

.knox-one-time {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  padding: 14px;
  background: rgba(255,255,255,0.04);
}

@media (max-width: 720px) {
  .knox-one-time { flex-direction: column; align-items: stretch; }
}

.knox-one-time-title { font-weight: 800; }
.knox-one-time-sub { margin-top: 4px; opacity: .7; font-size: 13px; }

.knox-one-time-title,
.knox-one-time-sub{
  color: rgba(255,255,255,0.92);
}

.knox-one-time-right {
  display:flex;
  align-items:center;
  gap: 10px;
}

.knox-select {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.92);
}

.knox-modal-note {
  margin: 12px 0 0 0;
  font-size: 12px;
  opacity: .6;
  color: rgba(255,255,255,0.72);
}

.knox-empty {
  border: 1px dashed rgba(255,255,255,0.18);
  border-radius: 16px;
  padding: 16px;
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.82);
}

/* FASE 2 - 4.2.6: Reward display in modal */
.knox-tier-reward {
  margin: 10px 0 12px 0;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
}

.knox-tier-reward--empty { opacity: .7; }

.knox-tier-reward-title {
  font-size: 12px;
  font-weight: 800;
  opacity: .7;
  margin-bottom: 6px;
  color: rgba(255,255,255,0.78);
}

.knox-tier-reward-body {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  font-size: 13px;
  color: rgba(255,255,255,0.90);
}

.knox-tier-reward-pill {
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(168, 85, 247, 0.18);
  border: 1px solid rgba(168, 85, 247, 0.35);
  color: #c084fc;
  font-weight: 700;
}

/* =========================================================
   FINAL: Reward borders (SAFE)
   ========================================================= */

/* Supporter ring */
.reward-border--supporter{
  border: 2px solid rgba(108,99,255,.85);
  box-shadow: 0 0 0 3px rgba(108,99,255,.10);
  border-radius: 999px;
  outline: none !important;
}

/* Extra reward borders (optioneel) */
.reward-border--vip {
  border: 3px solid #ff4fd8;
  box-shadow: 0 0 0 3px rgba(255, 79, 216, 0.14);
  border-radius: 50%;
}
.reward-border--og {
  border: 3px solid #ffb020;
  box-shadow: 0 0 0 3px rgba(255, 176, 32, 0.16);
  border-radius: 50%;
}
.reward-border--legend {
  border: 3px solid #00d4ff;
  box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.14);
  border-radius: 50%;
}
/* =========================
   RECENTE SUPPORTERS (creator page)
   - netjes in 1 rij
   - alleen avatar + naam
   ========================= */

.supporter-feed {
  margin-top: 12px;
}

.supporter-feed-title {
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 8px;
  color: #111827;
}

.supporter-feed-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* 1 rij: avatar links, tekst rechts */
.supporter-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* avatar bubble */
.supporter-avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  flex: 0 0 34px;

  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  display: flex;
  align-items: center;
  justify-content: center;

  font-weight: 800;
  font-size: 13px;
  color: #fff;

  background-color: rgba(15,23,42,0.85);
  border: 2px solid rgba(245, 246, 248, 0.95);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.18);
}

/* tekstblok */
.supporter-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.supporter-name {
  font-size: 13px;
  font-weight: 700;
  color: #111827;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Jij wil alleen avatar + naam -> badge verbergen */
.supporter-badge {
  display: none !important;
}
/* =====================================
   DEFAULT AVATAR + RECENTE SUPPORTERS
   (override – veilig onderaan)
   ===================================== */

.supporter-avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  border: 2px solid rgba(245,246,248,.95);
  box-shadow: 0 6px 14px rgba(15,23,42,.18);
}
/* GLOBAL AVATAR STYLE */
.avatar,
.supporter-avatar,
.creator-avatar img,
img.avatar {
  border-radius: 999px;
  object-fit: cover;
}
.top-supporter-row{
  display:flex;
  align-items:center;
  gap:10px;
}

.top-supporter-row .comment-avatar{
  width: 24px;
  height: 24px;
  border-radius: 999px;
  flex: 0 0 auto;
}

.top-supporter-name{
  font-size: 0.9rem;
}
.comment-avatar{
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background-size: cover;
  background-position: center;
  flex: 0 0 auto;
}



/* === App layout + Sidebar navigation === */
.knox-layout{
  display:flex;
  align-items:stretch;
  gap:18px;
  padding:12px;
  min-height:100%;
}

.knox-sidebar{
  width:220px;
  flex:0 0 220px;
  position:sticky;
  top:12px;
  height:calc(100vh - 24px);
  z-index:10;
}

.knox-sidebar-inner{
  height:100%;
  border-radius:0;
  border:none;
  background:#0b0f1a;
  box-shadow:none;
  padding:10px 10px;
  overflow:auto;
}

.knox-sidebar-search{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:10px;
  border:none;
  background:rgba(255,255,255,0.04);
  margin-bottom:10px;
}

.knox-sidebar-search-ico{display:inline-flex; opacity:0.9;}

.knox-sidebar-search-input{
  width:100%;
  border:0;
  outline:none;
  background:transparent;
  color:#e5e7eb;
  font-size:0.90rem;
}

.knox-sidebar-search-input::placeholder{color:rgba(229,231,235,0.60);}

.knox-snav{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.knox-snav-item{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 10px;
  border-radius:10px;
  text-decoration:none;
  color:rgba(229,231,235,0.78);
  border:0;
  background:transparent;
}

.knox-snav-ico{
  width:28px;
  height:28px;
  border-radius:8px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  border:none;
  opacity:0.75;
}

.knox-snav-ico svg{
  width:18px;
  height:18px;
}
.knox-snav-item:hover .knox-snav-ico,
.knox-snav-item.is-active .knox-snav-ico{
  opacity:1;
}
.knox-snav-item:hover{
  background:rgba(255,255,255,0.04);
  color:#ffffff;
}

.knox-snav-item.is-active{
  background:rgba(99,102,241,0.10);
  color:#ffffff;
}
.knox-snav-item.is-active::before{
  content:"";
  position:absolute;
  left:0;
  top:6px;
  bottom:6px;
  width:3px;
  border-radius:2px;
  background:rgba(99,102,241,0.95);
}

.knox-snav-label{font-weight:600; font-size:0.92rem;}

.knox-sidebar-foot{
  margin-top:14px;
  padding-top:10px;
  border-top:none;
}

.knox-sidebar-user{
  display:flex;
  align-items:center;
  gap:10px;
}

.knox-sidebar-user-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(99,102,241,0.9);
  box-shadow:0 0 0 4px rgba(99,102,241,0.18);
}

.knox-sidebar-user-name{color:#ffffff; font-weight:700; font-size:0.95rem;}
.knox-sidebar-user-role{color:rgba(229,231,235,0.65); font-size:0.82rem; text-transform:capitalize;}

/* Followed creators/users list (sidebar footer) */
.knox-following{margin-top:14px;}
.knox-following-title{
  font-size:0.72rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(229,231,235,0.60);
  margin:0 2px 8px;
}
.knox-following-list{display:flex; flex-direction:column; gap:6px;}
.knox-following-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:6px 8px;
  border-radius:14px;
  text-decoration:none;
  color:rgba(229,231,235,0.88);
  border:1px solid transparent;
}
.knox-following-item:hover{
  background:rgba(255,255,255,0.06);
  border-color:rgba(255,255,255,0.08);
  color:#fff;
}
.knox-following-avatar{
  width:34px;
  height:34px;
  border-radius:999px;
  flex:0 0 34px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  border:1px solid rgba(255,255,255,0.14);
  box-shadow:0 10px 24px rgba(0,0,0,0.25);
}
.knox-following-name{
  font-size:0.92rem;
  font-weight:650;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}


/* Content area */
body[data-auth="1"] .knox-content{margin-left:0;}
.knox-content{flex:1 1 auto; min-width:0; min-height:100%;}

/* Mobile: sidebar becomes off-canvas */
@media (max-width: 960px){
  .knox-sidebar{
    position:fixed;
    left:12px;
    top:84px;
    height:calc(100vh - 96px);
    transform:translateX(-120%);
    transition:transform 180ms ease;
  }
  body.knox-sidebar-open .knox-sidebar{transform:translateX(0);}
}

body[data-auth="1"] .site-footer{margin-top:0;}


/* === SHELL FIX: center sidebar+content as a unit (prevents giant empty gap) === */
body[data-auth="1"] .site-main{
  justify-content: center;
}

body[data-auth="1"] .knox-layout{
  width: 100%;
  max-width: 1560px; /* sidebar + content, mock-like */
  margin: 0 auto;
}

/* Keep a comfortable gap between sidebar and content */
body[data-auth="1"] .knox-layout{ gap: 22px; }


/* === Sidebar polish (match landing premium) === */
:root{
  --knox-radius-xl: 22px;
  --knox-border-1: rgba(255,255,255,0.10);
  --knox-border-2: rgba(255,255,255,0.16);
}

/* Slightly tighter + more premium sidebar proportions */
.knox-sidebar{ width:252px; flex:0 0 252px; }

.knox-sidebar-inner{
  position: relative;
  border-radius: var(--knox-radius-xl);
  border: 1px solid var(--knox-border-1);
  background:
    radial-gradient(900px 520px at 30% 0%, rgba(139,92,246,0.18) 0%, rgba(11,18,32,0) 55%),
    radial-gradient(760px 520px at 80% 25%, rgba(111,124,255,0.12) 0%, rgba(11,18,32,0) 55%),
    linear-gradient(180deg, rgba(17,24,39,0.82), rgba(6,10,26,0.92));
  box-shadow: 0 24px 70px rgba(0,0,0,0.42);
  padding: 14px 12px;
}

/* Pin button (desktop UX) */
.knox-sidebar-pin{
  position: absolute;
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: rgba(229,231,235,0.92);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3; /* above sheen */
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 160ms ease, opacity 160ms ease;
}

.knox-sidebar-pin:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,0.085);
  border-color: rgba(255,255,255,0.16);
}

.knox-sidebar-pin[aria-pressed="true"]{
  background: linear-gradient(135deg, rgba(139,92,246,0.32), rgba(111,124,255,0.14));
  border-color: rgba(139,92,246,0.38);
  box-shadow: 0 12px 26px rgba(139,92,246,0.18);
}

.knox-sidebar-pin-ico{display:inline-flex;}

@media (max-width: 979px){
  .knox-sidebar-pin{display:none;}
}

/* Floating tooltip (used when sidebar is collapsed) */
.knox-tooltip{
  position: fixed;
  z-index: 9999;
  transform: translateY(-50%);
  pointer-events: none;
  opacity: 0;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(17,24,39,0.92);
  backdrop-filter: saturate(140%) blur(10px);
  box-shadow: 0 18px 50px rgba(0,0,0,0.45);
  color: rgba(255,255,255,0.92);
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 0.01em;
  transition: opacity 120ms ease, transform 120ms ease;
  white-space: nowrap;
}

.knox-tooltip::before{
  content:"";
  position: absolute;
  left: -6px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 10px;
  height: 10px;
  background: rgba(17,24,39,0.92);
  border-left: 1px solid rgba(255,255,255,0.12);
  border-bottom: 1px solid rgba(255,255,255,0.12);
}

.knox-tooltip.is-show{
  opacity: 1;
  transform: translateY(-50%) translateX(2px);
}

/* Subtle top sheen */
.knox-sidebar-inner::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,0.09), rgba(255,255,255,0) 28%);
  opacity: 0.55;
}

/* Make search feel more "input-like" and crisp */
.knox-sidebar-search{
  border-color: rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.045);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

.knox-sidebar-search:focus-within{
  border-color: rgba(139,92,246,0.40);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.06),
    0 0 0 4px rgba(139,92,246,0.14);
}

/* Nav items: more punch + better hierarchy */
.knox-snav{ gap: 6px; }

.knox-snav-item{
  position: relative;
  transition: background 160ms ease, transform 160ms ease, border-color 160ms ease, color 160ms ease;
}

.knox-snav-item:hover{
  background: rgba(255,255,255,0.075);
  border-color: rgba(255,255,255,0.10);
  transform: translateY(-1px);
}

/* Active indicator bar + stronger gradient */
.knox-snav-item.is-active{
  background: linear-gradient(90deg, rgba(139,92,246,0.34), rgba(111,124,255,0.10) 55%, rgba(255,255,255,0.04));
  border-color: rgba(139,92,246,0.42);
}

.knox-snav-item.is-active::before{
  content:"";
  position:absolute;
  left:8px;
  top:10px;
  bottom:10px;
  width:3px;
  border-radius:999px;
  background: linear-gradient(180deg, rgba(139,92,246,1), rgba(111,124,255,0.95));
  box-shadow: 0 0 0 4px rgba(139,92,246,0.14);
}

.knox-snav-ico{
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.knox-snav-item:hover .knox-snav-ico{ transform: translateY(-1px); }

.knox-snav-item.is-active .knox-snav-ico{
  background: linear-gradient(135deg, rgba(139,92,246,0.35), rgba(111,124,255,0.18));
  border-color: rgba(139,92,246,0.38);
  box-shadow: 0 10px 24px rgba(139,92,246,0.18);
}

/* Footer separation: a bit cleaner */
.knox-sidebar-foot{
  border-top-color: rgba(255,255,255,0.12);
}

/* === Collapsible sidebar (icons-only → expand on hover) ===
   - Desktop only (hover + fine pointer)
   - Expands on :hover and :focus-within for accessibility
*/
@media (hover: hover) and (pointer: fine) and (min-width: 980px){
  .knox-sidebar{
    width: 86px;
    flex: 0 0 86px;
    transition: width 220ms ease, flex-basis 220ms ease;
  }

  /* Pinned: stay expanded even without hover */
  body.knox-sidebar-pinned .knox-sidebar{
    width: 252px;
    flex: 0 0 252px;
  }

  .knox-sidebar:hover,
  .knox-sidebar:focus-within{
    width: 252px;
    flex: 0 0 252px;
  }

  /* Keep inner layout stable while animating */
  .knox-sidebar-inner{ overflow: hidden; }

  /* Labels collapse */
  .knox-snav-label{
    white-space: nowrap;
    overflow: hidden;
    max-width: 200px;
    transition: max-width 200ms ease, opacity 160ms ease, transform 200ms ease;
  }

  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-snav-label{
    max-width: 0;
    opacity: 0;
    transform: translateX(-6px);
  }

  /* Center nav items when collapsed */
  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-snav-item{
    justify-content: center;
    padding-left: 10px;
    padding-right: 10px;
  }

  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-snav-item.is-active::before{
    left: 6px; /* keep indicator visible */
  }

  /* Search: icon-only when collapsed */
  .knox-sidebar-search-input{
    transition: width 200ms ease, opacity 160ms ease;
  }

  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-sidebar-search{
    justify-content: center;
  }

  /* Pin button: hide while fully-collapsed to avoid overlap with the search icon.
     Users can hover/focus to expand, then pin the sidebar. */
  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-sidebar-pin{
    opacity: 0;
    pointer-events: none;
    transform: translateY(-6px);
  }

  .knox-sidebar:hover .knox-sidebar-pin,
  .knox-sidebar:focus-within .knox-sidebar-pin,
  .knox-sidebar.is-pinned .knox-sidebar-pin{
    opacity: 1;
    pointer-events: auto;
    transform: none;
  }

  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-sidebar-search-input{
    width: 0;
    opacity: 0;
    padding: 0;
    margin: 0;
    border: 0;
  }

  /* Footer/user + following: avatars can remain, text collapses */
  .knox-sidebar-user-meta,
  .knox-following-title,
  .knox-following-name{ transition: opacity 160ms ease, transform 200ms ease; }

  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-sidebar-user{
    justify-content: center;
  }

  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-sidebar-user-meta,
  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-following-title,
  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-following-name{
    opacity: 0;
    transform: translateX(-6px);
    pointer-events: none;
    height: 0;
    overflow: hidden;
  }

  .knox-sidebar:not(.is-pinned):not(:hover):not(:focus-within) .knox-following-item{
    justify-content: center;
    padding-left: 10px;
    padding-right: 10px;
  }

  /* Tooltips are rendered via JS as a floating element (prevents clipping) */
}


/* =========================
   Support / Subscribe modal UX polish
========================= */
html.knox-modal-open, body.knox-modal-open { overflow: hidden; }

.knox-modal-overlay { opacity: 0; transform: translateY(6px); transition: opacity .18s ease, transform .18s ease; }
.knox-modal-overlay.is-open { opacity: 1; transform: translateY(0); }

.knox-tier-card { cursor: pointer; transition: transform .12s ease, border-color .12s ease, background .12s ease; }
.knox-tier-card:hover { transform: translateY(-1px); border-color: rgba(255,255,255,0.18); background: rgba(255,255,255,0.08); }

.knox-tier-card.is-selected { border-color: rgba(168,85,247,0.55); box-shadow: 0 0 0 3px rgba(168,85,247,0.12), inset 0 1px 0 rgba(255,255,255,0.06); }

button.is-loading { opacity: .85; cursor: progress !important; }


/* Admin users table: make columns fit and actions usable */
.table-users { table-layout: auto; width: 100%; }
.table-users th, .table-users td { padding: .6rem .75rem; vertical-align: top; }
.table-users th { font-size: 12px; letter-spacing: .02em; text-transform: none; }
.table-users .table-meta { font-size: 12px; opacity: .85; }

.table-users th:nth-child(1), .table-users td:nth-child(1) { width: 18%; }
.table-users th:nth-child(2), .table-users td:nth-child(2) { width: 8%; }
.table-users th:nth-child(3), .table-users td:nth-child(3) { width: 10%; }
.table-users th:nth-child(4), .table-users td:nth-child(4) { width: 22%; }
.table-users th:nth-child(5), .table-users td:nth-child(5) { width: 6%; text-align:center; }
.table-users th:nth-child(6), .table-users td:nth-child(6) { width: 8%; text-align:center; }
.table-users th:nth-child(7), .table-users td:nth-child(7) { width: 28%; }

.admin-actions { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; }
.admin-actions .btn-secondary,
.admin-actions .btn-secondary.btn-link {
  padding: .35rem .65rem;
  font-size: 12px;
  line-height: 1.15;
  border-radius: 999px;
  white-space: nowrap;      /* prevent vertical letter stacking */
  flex: 0 0 auto;           /* don't shrink to unreadable widths */
}
.admin-actions .btn-secondary.btn-link { display: inline-flex; align-items: center; text-decoration: none; }

/* Keep follows column readable */
.table-users td:nth-child(4) { white-space: normal; word-break: break-word; }


/* --- Knoxlink fix: section header button overflow (creator dashboard) --- */
.section-header{
  align-items: center; /* was baseline; causes weird vertical alignment */
  gap: 1rem;
  flex-wrap: wrap; /* allow wrapping on smaller widths */
}
.section-header > :first-child{
  flex: 1 1 auto;
  min-width: 0; /* allow text block to shrink instead of pushing button out */
}
.section-header > :last-child{
  flex: 0 0 auto;
  margin-left: auto;
}


/* Formatted post content */
.post-bullets {
  margin: 0.35rem 0 0.6rem 1.15rem;
  padding: 0;
}
.post-bullets li {
  margin: 0.2rem 0;
}
.post-content a {
  color: #a78bfa;
  text-decoration: underline;
}
.post-content p {
  margin: 0.35rem 0 0.65rem;
}


/* ===============================
   Responsive Hamburger Fix
   =============================== */

/* Base hamburger style */
.menu-toggle {
    width: 30px;
    height: 22px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    background: none;
    border: none;
    cursor: pointer;
}

.menu-toggle span {
    display: block;
    height: 3px;
    width: 100%;
    background-color: #000;
    border-radius: 2px;
}

/* Hide hamburger on desktop */
@media (min-width: 980px) {
    .menu-toggle {
        display: none !important;
    }
}

/* === OVERRIDES: Sidebar always expanded (no hover expand) + hide pin button === */
.knox-sidebar-pin{ display:none !important; }

@media (hover: hover) and (pointer: fine) and (min-width: 980px){
  /* Force expanded width on desktop */
  .knox-sidebar{
    width: 205px !important;
    flex: 0 0 205px !important;
    transition: none !important;
  }
  /* Keep inner scroll behavior */
  .knox-sidebar-inner{
    overflow: auto !important;
  }
  /* Never collapse labels */
  .knox-snav-label{
    max-width: 200px !important;
    opacity: 1 !important;
    transform: none !important;
  }
  /* Normal nav item alignment */
  .knox-snav-item{
    justify-content: flex-start !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  /* Search always visible */
  .knox-sidebar-search{ justify-content: flex-start !important; }
  .knox-sidebar-search-input{
    width: 100% !important;
    opacity: 1 !important;
    padding: inherit !important;
    margin: inherit !important;
    border: inherit !important;
  }
}

/* Ultra Quiet Sidebar (flat, square, low-contrast) */
.knox-sidebar-inner{
  background:#0b0f1a !important;
  box-shadow:none !important;
  border:none !important;
}

.knox-snav-label{
  color:rgba(255,255,255,0.65) !important;
}

.knox-snav-ico{
  opacity:0.60 !important;
  background:transparent !important;
  border:none !important;
}

.knox-snav-item{
  background:transparent !important;
}

.knox-snav-item:hover{
  background:rgba(255,255,255,0.02) !important;
}

.knox-snav-item.is-active{
  background:rgba(255,255,255,0.03) !important;
  border-left:2px solid rgba(139,92,246,0.8) !important;
}

.knox-snav-item.is-active .knox-snav-label{
  color:rgba(255,255,255,0.92) !important;
}

.knox-snav-item.is-active .knox-snav-ico{
  opacity:1 !important;
}

/* Search: quieter */
.knox-snav-search{
  background:rgba(255,255,255,0.04) !important;
  border:none !important;
}

.knox-snav-search input{
  color:rgba(255,255,255,0.82) !important;
}

.knox-snav-search input::placeholder{
  color:rgba(255,255,255,0.45) !important;
}

/* Keep sidebar fully square (no rounded corners) */
.knox-sidebar,
.knox-sidebar-inner,
.knox-shell,
.knox-snav,
.knox-snav-item,
.knox-snav-search,
.knox-snav-search input,
.knox-snav-ico{
  border-radius:0 !important;
}

.knox-sidebar-inner::before,
.knox-sidebar-inner::after,
.knox-snav-search::before,
.knox-snav-search::after{
  border-radius:0 !important;
}/* Desktop: sidebar always flush-left and fixed; mobile keeps hamburger */
@media (min-width: 980px) and (hover: hover) and (pointer: fine){
  .knox-sidebar{
    position: fixed !important;
    left: 0 !important;
    top: 0 !important;
    height: 100vh !important;
    z-index: 50 !important;
  }

  /* Push the page content to the right of the fixed sidebar */
  .knox-layout{
    margin-left: 205px !important;
  }

  /* Avoid double offsets */
  .knox-content{
    margin-left: 0 !important;
  }
}
