
:root {
  --black: #0A0A0A;
  --surface: #111111;
  --surface2: #1A1A1A;
  --white: #FAFAFA;
  --neon: #C8FF00;
  --purple: #7B2FFF;
  --pink: #FF2D78;
  --orange: #FF4D00;
  --glass: rgba(255,255,255,0.06);
  --glass-border: rgba(255,255,255,0.10);
  --font-display: 'Bebas Neue', sans-serif;
  --font-body: 'DM Sans', sans-serif;
}
* { margin:0; padding:0; box-sizing:border-box; }
body { background: var(--black); color: var(--white); font-family: var(--font-body); min-height:100vh; }
a { color: inherit; }

.app-shell { display:grid; grid-template-columns:240px 1fr 300px; min-height:100vh; }
.sidebar {
  position:fixed; top:0; left:0; bottom:0; width:240px;
  background:var(--surface); border-right:1px solid var(--glass-border);
  display:flex; flex-direction:column; z-index:10;
}
.sidebar-logo {
  padding:24px 24px 20px; border-bottom:1px solid var(--glass-border);
  font-family:var(--font-display); font-size:28px; letter-spacing:3px;
  text-decoration:none; color:var(--white);
}
.sidebar-logo span { color:var(--neon); }
.sidebar-nav { flex:1; padding:16px 12px; display:flex; flex-direction:column; gap:4px; overflow:auto; }
.nav-section-label {
  font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,0.25); padding:16px 14px 8px;
}
.nav-item {
  display:flex; align-items:center; gap:12px; padding:12px 14px; border-radius:12px;
  text-decoration:none; color:rgba(255,255,255,0.55); font-size:14px; font-weight:500;
  transition:all .2s;
}
.nav-item:hover { background:var(--glass); color:var(--white); }
.nav-item.active { background:rgba(200,255,0,0.1); color:var(--neon); }
.nav-item-icon { font-size:18px; width:24px; text-align:center; }
.sidebar-upload { padding:16px 12px; border-top:1px solid var(--glass-border); }
.upload-btn {
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 16px; border-radius:14px; background:var(--neon);
  color:var(--black); text-decoration:none; font-weight:800;
}
.sidebar-user {
  padding:16px 14px 18px; border-top:1px solid var(--glass-border); display:flex; gap:12px; align-items:center;
}
.user-avatar {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  display:flex; align-items:center; justify-content:center; font-weight:800;
}
.user-name { font-size:14px; font-weight:700; }
.user-handle { font-size:12px; color:rgba(255,255,255,0.45); }

.main-content { margin-left:240px; min-width:0; }
.right-panel {
  position:fixed; top:0; right:0; bottom:0; width:300px;
  background:var(--surface); border-left:1px solid var(--glass-border);
  padding:24px 20px; overflow:auto;
}
.topbar {
  position:sticky; top:0; z-index:5; padding:18px 24px;
  background:rgba(10,10,10,.86); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--glass-border);
}
.search-bar {
  display:flex; align-items:center; gap:10px; background:var(--surface2);
  border:1px solid var(--glass-border); border-radius:100px; padding:10px 16px;
}
.search-bar input {
  flex:1; background:none; border:none; outline:none; color:var(--white);
  font-family:var(--font-body); font-size:14px;
}
.search-bar input::placeholder { color:rgba(255,255,255,.3); }

.page-body { padding:24px; }
.page-header { margin-bottom:22px; }
.page-kicker {
  font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,.34); margin-bottom:10px;
}
.page-title {
  font-family:var(--font-display); font-size:56px; line-height:.95; letter-spacing:2px;
}
.page-sub { margin-top:10px; color:rgba(255,255,255,.54); line-height:1.7; max-width:760px; }

.panel {
  background:var(--surface); border:1px solid var(--glass-border); border-radius:20px; padding:20px;
}
.panel + .panel { margin-top:18px; }
.grid-2 { display:grid; grid-template-columns:1.2fr .8fr; gap:20px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.info-card {
  background:var(--surface2); border:1px solid var(--glass-border); border-radius:18px; padding:18px;
}
.info-card strong {
  display:block; font-family:var(--font-display); font-size:34px; color:var(--neon); line-height:1;
}
.muted { color:rgba(255,255,255,.52); }
.mini-item {
  padding:14px; border-radius:14px; background:rgba(255,255,255,.03);
  border:1px solid var(--glass-border); margin-bottom:10px;
}
.mini-item-title { font-size:13px; font-weight:700; margin-bottom:4px; }
.mini-item-sub { font-size:12px; color:rgba(255,255,255,.45); line-height:1.5; }

.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
label {
  display:block; font-size:12px; font-weight:600; letter-spacing:1.2px; text-transform:uppercase;
  color:rgba(255,255,255,.45); margin-bottom:8px;
}
input, textarea, select {
  width:100%; padding:14px 16px; border-radius:14px;
  border:1px solid var(--glass-border); background:var(--glass); color:var(--white);
  font-family:var(--font-body); outline:none;
}
textarea { resize:vertical; }
button {
  padding:14px 18px; border:none; border-radius:14px;
  background:var(--neon); color:var(--black); font-weight:800; cursor:pointer;
}
.button-secondary {
  background:var(--glass); color:var(--white); border:1px solid var(--glass-border);
}
.empty-state {
  padding:24px; border:1px dashed var(--glass-border);
  border-radius:18px; color:rgba(255,255,255,.5); background:rgba(255,255,255,.02);
}
.viewer-shell { position:fixed; inset:0; background:#000; }
.viewer-ui {
  position:absolute; top:20px; left:20px; right:20px; z-index:10;
  display:flex; justify-content:space-between; align-items:flex-start; gap:16px;
}
.viewer-chip {
  max-width:60vw; padding:12px 14px; border-radius:14px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14);
  font-size:13px; color:rgba(255,255,255,.8);
}
canvas#canvas { display:block; width:100%; height:100%; }

.panel-title {
  font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,.3); margin-bottom:14px;
}
.side-card {
  background:var(--surface2); border:1px solid var(--glass-border); border-radius:18px; padding:16px; margin-bottom:18px;
}
.side-stat { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px solid rgba(255,255,255,.06); }
.side-stat:last-child { border-bottom:none; }
.side-label { font-size:13px; color:rgba(255,255,255,.55); }
.side-value { font-size:13px; font-weight:700; }

@media (max-width: 1100px){
  .app-shell { grid-template-columns:220px 1fr; }
  .sidebar { width:220px; }
  .main-content { margin-left:220px; }
  .right-panel { display:none; }
}
@media (max-width: 820px){
  .app-shell { display:block; }
  .sidebar { position:relative; width:100%; height:auto; }
  .main-content { margin-left:0; }
  .grid-2,.grid-3,.form-grid { grid-template-columns:1fr; }
}

/* Frontend polish pass */
.main-content { margin-right: 300px; }
.page-body { padding: 32px; max-width: 1600px; }
.page-header { margin-bottom: 28px; }
.panel, .info-card, .side-card, .mini-item { box-shadow: 0 10px 30px rgba(0,0,0,0.18); }
.page-title { margin-bottom: 6px; }
.grid-2.tight { grid-template-columns: 1.35fr .65fr; }
.stack-18 { display:grid; gap:18px; }
.feed-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 22px; }
.feed-card {
  background: var(--surface); border:1px solid var(--glass-border); border-radius: 22px; overflow:hidden;
  transition: transform .25s, border-color .25s, box-shadow .25s; cursor:pointer;
}
.feed-card:hover { transform: translateY(-4px); border-color: rgba(200,255,0,.22); box-shadow: 0 14px 34px rgba(0,0,0,.25); }
.feed-card.featured { grid-column: span 2; display:grid; grid-template-columns: 1.05fr .95fr; }
.feed-visual { min-height: 280px; position:relative; display:flex; align-items:flex-end; padding:18px; }
.feed-card:not(.featured) .feed-visual { min-height: 250px; }
.feed-pill {
  position:absolute; top:16px; left:16px; padding:6px 10px; border-radius:999px;
  background: rgba(0,0,0,.55); border:1px solid rgba(255,255,255,.12); font-size:12px; letter-spacing:.06em;
}
.feed-open {
  background: rgba(0,0,0,.45); border:1px solid rgba(255,255,255,.12); border-radius:999px; padding:8px 12px; font-size:12px;
}
.feed-copy { padding: 20px; }
.feed-copy h3 { font-size: 26px; line-height: 1.15; margin-bottom: 10px; }
.feed-copy p { color: rgba(255,255,255,.58); line-height: 1.7; margin-bottom: 14px; }
.feed-tags { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:14px; }
.feed-tag { padding:6px 10px; border-radius:999px; background: var(--glass); border:1px solid var(--glass-border); font-size:12px; color:rgba(255,255,255,.76); }
.feed-meta { display:flex; flex-wrap:wrap; gap:10px; }
.feed-meta-badge { padding:8px 10px; border-radius:999px; background: var(--glass); border:1px solid var(--glass-border); font-size:12px; color:rgba(255,255,255,.72); }
.hero-metric { display:grid; gap:16px; }
.hero-metric .info-card { min-height: 128px; }
.profile-hero { display:grid; grid-template-columns: 96px 1fr; gap:20px; align-items:center; }
.profile-avatar {
  width:96px; height:96px; border-radius:28px; background: linear-gradient(135deg,var(--purple),var(--pink));
  display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:42px;
}
.panel-subtitle { color:rgba(255,255,255,.48); line-height:1.7; margin-top:8px; }
.right-panel .mini-item:last-child { margin-bottom:0; }

@media (max-width: 1100px){
  .main-content { margin-right: 0; }
  .page-body { padding: 26px; }
}
@media (max-width: 820px){
  .page-body { padding: 20px; }
  .feed-grid, .feed-card.featured, .grid-2.tight { grid-template-columns: 1fr; display:block; }
  .feed-card.featured .feed-copy { border-top:1px solid var(--glass-border); }
  .profile-hero { grid-template-columns: 1fr; }
}

/* Final layout fix: remove double-squeeze from grid + fixed sidebars */
html, body {
  width: 100%;
  overflow-x: hidden;
}
.app-shell {
  display: block;
  min-height: 100vh;
}
.sidebar {
  width: 260px;
}
.right-panel {
  width: 320px;
}
.main-content {
  margin-left: 260px;
  margin-right: 320px;
  min-height: 100vh;
  width: auto;
}
.topbar {
  padding: 20px 28px;
}
.topbar .search-bar {
  width: min(100%, 980px);
  margin: 0 auto;
}
.page-body {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 42px 42px 56px;
}
.page-header {
  text-align: center;
  margin-bottom: 36px;
}
.page-title,
.page-kicker,
.page-sub {
  width: 100%;
}
.panel,
.info-card,
.side-card {
  width: 100%;
}
.form-grid {
  grid-template-columns: repeat(2, minmax(240px, 1fr));
}
.grid-2 {
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
}
.grid-2.tight {
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.65fr);
}
.feed-grid {
  grid-template-columns: repeat(2, minmax(320px, 1fr));
}
.feed-card.featured {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
}
@media (max-width: 1280px) {
  .right-panel {
    width: 300px;
  }
  .main-content {
    margin-right: 300px;
  }
  .page-body {
    max-width: 1180px;
    padding: 34px 30px 48px;
  }
}
@media (max-width: 1100px) {
  .sidebar {
    width: 230px;
  }
  .main-content {
    margin-left: 230px;
    margin-right: 0;
  }
  .right-panel {
    display: none;
  }
  .page-body,
  .topbar .search-bar {
    max-width: 100%;
  }
}
@media (max-width: 820px) {
  .sidebar {
    position: relative;
    width: 100%;
  }
  .main-content {
    margin-left: 0;
    margin-right: 0;
  }
  .topbar {
    padding: 16px 18px;
  }
  .page-body {
    padding: 24px 18px 34px;
  }
  .page-header {
    text-align: left;
  }
  .form-grid,
  .grid-2,
  .grid-2.tight,
  .feed-grid,
  .feed-card.featured {
    display: grid;
    grid-template-columns: 1fr;
  }
}

.viewer-page {
  overflow: hidden;
}

.premium-viewer-shell {
  background:
    radial-gradient(circle at 18% 20%, rgba(123,47,255,0.24), transparent 30%),
    radial-gradient(circle at 82% 16%, rgba(255,45,120,0.18), transparent 24%),
    radial-gradient(circle at 50% 100%, rgba(200,255,0,0.10), transparent 32%),
    #05070b;
}

.viewer-backdrop {
  position: absolute;
  inset: 0;
  backdrop-filter: blur(2px);
  pointer-events: none;
  z-index: 2;
}


.viewer-stage {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
}

.viewer-stage canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;
}


.glass-bar,
.glass-panel {
  background: rgba(14, 16, 22, 0.68);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 18px 60px rgba(0,0,0,0.32);
  backdrop-filter: blur(18px);
}

.viewer-topbar {
  position: absolute;
  top: 20px;
  left: 20px;
  right: 20px;
  z-index: 20;
  border-radius: 24px;
  padding: 18px 20px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}

.viewer-brand-group {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.viewer-back-btn {
  white-space: nowrap;
}

.viewer-overline {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(255,255,255,0.48);
  margin-bottom: 8px;
}

.viewer-title {
  font-family: var(--font-display);
  font-size: clamp(32px, 5vw, 64px);
  line-height: 0.95;
  letter-spacing: 0.04em;
}

.viewer-chip-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  max-width: 520px;
}

.accent-chip {
  color: var(--neon);
  font-weight: 800;
}

.viewer-side-panel {
  position: absolute;
  right: 20px;
  top: 122px;
  bottom: 112px;
  width: min(360px, calc(100vw - 40px));
  z-index: 20;
  border-radius: 28px;
  padding: 20px;
  display: grid;
  gap: 18px;
  align-content: start;
}

.viewer-side-block {
  display: grid;
  gap: 12px;
}

.viewer-mode-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.viewer-mode-btn {
  padding: 12px 10px;
  border-radius: 14px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--white);
  font-weight: 700;
}

.viewer-mode-btn.active {
  background: rgba(200,255,0,0.12);
  color: var(--neon);
  border-color: rgba(200,255,0,0.24);
}

.viewer-actions-stack {
  display: grid;
  gap: 10px;
}

.viewer-cta {
  border-radius: 16px;
  padding: 14px 16px;
  font-weight: 800;
}

.viewer-cta-primary {
  background: var(--neon);
  color: var(--black);
}

.viewer-cta-secondary {
  background: rgba(255,255,255,0.06);
  color: var(--white);
  border: 1px solid rgba(255,255,255,0.1);
}

.viewer-highlight-list {
  display: grid;
  gap: 10px;
}

.viewer-highlight-item {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.82);
  line-height: 1.5;
}

.viewer-bottom-rail {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 20px;
  z-index: 20;
  border-radius: 24px;
  padding: 14px 18px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, 1fr);
}

.viewer-stat {
  display: grid;
  gap: 4px;
}

.viewer-stat-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.42);
}

.viewer-stat strong {
  font-size: 14px;
}

body[data-viewer-mode="car"] .viewer-title,
body[data-viewer-mode="car"] .accent-chip {
  color: var(--neon);
}

body[data-viewer-mode="property"] .viewer-title,
body[data-viewer-mode="property"] .accent-chip {
  color: #ff97d0;
}

body[data-viewer-mode="event"] .viewer-title,
body[data-viewer-mode="event"] .accent-chip {
  color: #ff9d7b;
}

@media (max-width: 1080px) {
  .viewer-topbar {
    flex-direction: column;
  }
  .viewer-chip-stack {
    justify-content: flex-start;
    max-width: none;
  }
  .viewer-side-panel {
    width: 100%;
    left: 20px;
    right: 20px;
    top: auto;
    bottom: 110px;
    max-height: 42vh;
    overflow: auto;
  }
}

@media (max-width: 720px) {
  .viewer-topbar,
  .viewer-bottom-rail,
  .viewer-side-panel {
    left: 14px;
    right: 14px;
  }
  .viewer-topbar {
    top: 14px;
    padding: 14px;
  }
  .viewer-side-panel {
    bottom: 104px;
    padding: 14px;
  }
  .viewer-title {
    font-size: 34px;
  }
  .viewer-mode-grid,
  .viewer-bottom-rail {
    grid-template-columns: 1fr;
  }
}
