:root {
  --bg: #0d1020;
  --bg2: #12152b;
  --panel: rgba(255,255,255,.075);
  --panel2: rgba(255,255,255,.12);
  --panel3: rgba(255,255,255,.17);
  --text: #f6f7fb;
  --muted: #aab0c0;
  --line: rgba(255,255,255,.13);
  --accent: #8b5cf6;
  --accent2: #06b6d4;
  --danger: #ef4444;
  --ok: #22c55e;
  --warn: #f59e0b;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(139,92,246,.32), transparent 30rem),
    radial-gradient(circle at top right, rgba(6,182,212,.23), transparent 24rem),
    radial-gradient(circle at 50% 15%, rgba(255,255,255,.09), transparent 18rem),
    linear-gradient(135deg, #090b16, var(--bg) 45%, #131426);
  min-height: 100vh;
  padding-bottom: env(safe-area-inset-bottom);
}
body:before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .22;
  background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(to bottom, black, transparent 72%);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, textarea, select { font: inherit; }
.topbar {
  position: sticky; top: 0; z-index: 40;
  display: grid; grid-template-columns: minmax(200px, 290px) minmax(200px, 520px) 1fr;
  align-items: center; gap: .85rem;
  padding: .85rem clamp(1rem, 3vw, 2rem);
  backdrop-filter: blur(20px);
  background: rgba(9,11,22,.78);
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: .75rem; min-width: 0; }
.brand-mark {
  width: 46px; height: 46px; border-radius: 17px;
  display: grid; place-items: center; font-weight: 950;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow: 0 10px 30px rgba(139,92,246,.32);
  flex: 0 0 auto;
}
.brand strong { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.brand small { display: block; color: var(--muted); font-size: .76rem; margin-top: .15rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.top-search input { height: 44px; border-radius: 999px; }
.nav { display: flex; align-items: center; gap: .25rem; flex-wrap: wrap; justify-content: flex-end; }
.nav a, .btn, button.btn {
  border: 1px solid transparent; background: transparent; color: var(--text);
  padding: .68rem .86rem; border-radius: 999px; cursor: pointer; font-weight: 800;
}
.nav a:hover, .nav a.active, .btn:hover { background: var(--panel2); border-color: var(--line); }
.btn, button.btn, .nav a.btn { background: linear-gradient(135deg, var(--accent), var(--accent2)); color: white; border: 0; box-shadow: 0 12px 30px rgba(6,182,212,.14); }
.btn.secondary { background: var(--panel2); border: 1px solid var(--line); box-shadow: none; }
.btn.ghost { background: transparent; border: 1px solid var(--line); box-shadow: none; }
.btn.danger { background: var(--danger); }
.btn.small { padding: .52rem .78rem; font-size: .9rem; }
.nav-toggle { display: none; }
.badge { background: var(--danger); border-radius: 999px; padding: .1rem .42rem; font-size: .72rem; }
.shell { width: min(1180px, calc(100% - 2rem)); margin: 1.1rem auto 3rem; position: relative; z-index: 1; }
.app-grid { display: grid; grid-template-columns: 250px minmax(0, 1fr) 310px; gap: 1rem; align-items: start; }
.grid { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 1rem; align-items: start; }
.left-rail, .right-rail { position: sticky; top: 88px; display: grid; gap: 1rem; }
.card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 26px;
  padding: 1rem; box-shadow: 0 22px 70px rgba(0,0,0,.25);
}
.glass { background: rgba(255,255,255,.055); backdrop-filter: blur(12px); }
.hero { padding: clamp(1.2rem, 5vw, 4rem); min-height: 520px; display: grid; place-items: center; text-align: center; position: relative; overflow: hidden; }
.hero:before { content: ''; position: absolute; inset: -20%; background: radial-gradient(circle, rgba(255,255,255,.14), transparent 18rem); animation: floatGlow 7s ease-in-out infinite alternate; }
.hero:after { content: ''; position: absolute; inset: 0; background: linear-gradient(130deg, transparent 20%, rgba(255,255,255,.08), transparent 70%); transform: translateX(-100%); animation: shine 8s ease-in-out infinite; }
.hero > * { position: relative; z-index: 1; }
.hero h1 { font-size: clamp(2.3rem, 7vw, 5.8rem); line-height: .95; margin: 0 0 1rem; letter-spacing: -.06em; }
.hero p { color: var(--muted); font-size: 1.15rem; max-width: 760px; margin: 0 auto 1.5rem; }
@keyframes floatGlow { from { transform: translate(-3%, -2%) rotate(0deg); } to { transform: translate(3%, 2%) rotate(8deg); } }
@keyframes shine { 0%,60%{transform:translateX(-100%)} 100%{transform:translateX(100%)} }
.composer { scroll-margin-top: 100px; }
.composer-top { display: flex; gap: .75rem; align-items: flex-start; }
.composer textarea, input, select, textarea {
  width: 100%; border: 1px solid var(--line); border-radius: 18px; padding: .9rem 1rem;
  background: rgba(255,255,255,.06); color: var(--text); outline: none;
}
textarea { min-height: 110px; resize: vertical; }
input::placeholder, textarea::placeholder { color: #777f96; }
select option { color: #0d1020; }
.form-grid { display: grid; gap: .85rem; }
.form-row { display: grid; gap: .35rem; }
.form-row label { color: var(--muted); font-size: .9rem; font-weight: 800; }
.post { display: grid; gap: .85rem; overflow: hidden; }
.post + .post { margin-top: 1rem; }
.post-head { display: flex; align-items: center; gap: .75rem; }
.post-head-main { min-width: 0; flex: 1; }
.post-menu { margin-left: auto; display: flex; gap: .35rem; flex-wrap: wrap; justify-content: flex-end; }
.avatar { width: 46px; height: 46px; object-fit: cover; border-radius: 50%; border: 2px solid var(--line); background: var(--panel2); }
.avatar.big { width: 112px; height: 112px; }
.avatar.tiny { width: 34px; height: 34px; }
.muted { color: var(--muted); }
.post-content { white-space: normal; line-height: 1.55; overflow-wrap: anywhere; }
.tag-link, .mention-link { color: #a5f3fc; font-weight: 900; }
.media-grid { display: grid; gap: .45rem; border-radius: 24px; overflow: hidden; }
.media-grid.count-1 { display: block; }
.media-grid.count-2 { grid-template-columns: 1fr 1fr; }
.media-grid.count-3 { grid-template-columns: 1fr 1fr; }
.media-grid.count-3 a:first-child { grid-row: span 2; }
.media-grid.count-4, .media-grid.count-many { grid-template-columns: 1fr 1fr; }
.post-img, .media-grid img { border: 1px solid var(--line); width: 100%; height: 100%; object-fit: cover; background: rgba(255,255,255,.05); }
.media-grid.count-1 img { border-radius: 24px; max-height: 620px; object-fit: cover; }
.media-grid.count-2 img, .media-grid.count-4 img, .media-grid.count-many img { aspect-ratio: 1 / 1; }
.media-grid.count-3 img { aspect-ratio: 1 / 1; min-height: 170px; }
.media-grid.count-3 a:first-child img { aspect-ratio: auto; height: 100%; }
.lightbox-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.82); z-index: 100; display: none; align-items: center; justify-content: center; padding: 1rem; }
.lightbox-backdrop.open { display: flex; }
.lightbox-backdrop img { max-width: min(1100px, 96vw); max-height: 90vh; border-radius: 24px; border: 1px solid var(--line); }
.actions { display: flex; align-items: center; gap: .55rem; flex-wrap: wrap; }
.inline-form { display: inline; }
.stats { display: flex; gap: 1rem; color: var(--muted); flex-wrap: wrap; }
.stat-cards { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .75rem; }
.stat-card { padding: 1rem; border: 1px solid var(--line); border-radius: 22px; background: rgba(255,255,255,.055); }
.stat-card strong { display: block; font-size: 1.65rem; }
.profile-cover { min-height: 245px; border-radius: 28px; background: linear-gradient(135deg, rgba(139,92,246,.5), rgba(6,182,212,.35)), rgba(255,255,255,.07); border: 1px solid var(--line); overflow: hidden; }
.profile-cover img { width: 100%; height: 280px; object-fit: cover; }
.profile-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-top: -58px; padding: 0 1rem 1rem; }
.profile-id { display: flex; align-items: flex-end; gap: 1rem; }
.profile-tabs { display: flex; gap: .45rem; flex-wrap: wrap; padding: 0 1rem 1rem; }
.profile-tabs a { padding: .6rem .9rem; border-radius: 999px; border: 1px solid var(--line); background: rgba(255,255,255,.045); color: var(--muted); font-weight: 800; }
.profile-tabs a.active { background: var(--panel2); color: var(--text); }
.list { display: grid; gap: .75rem; }
.user-row, .note-row, .message-row, .trend-row { display: flex; gap: .75rem; align-items: flex-start; padding: .8rem; background: rgba(255,255,255,.05); border-radius: 18px; border: 1px solid var(--line); }
.user-row:hover, .trend-row:hover { background: rgba(255,255,255,.08); }
.message-row.me { margin-left: 15%; background: rgba(139,92,246,.16); }
.message-row.them { margin-right: 15%; }
.alert { padding: .9rem 1rem; border-radius: 18px; margin-bottom: 1rem; border: 1px solid var(--line); }
.alert.error { background: rgba(239,68,68,.16); }
.alert.success { background: rgba(34,197,94,.16); }
.alert.info { background: rgba(6,182,212,.13); }
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: .75rem; border-bottom: 1px solid var(--line); vertical-align: top; }
.footer { width: min(1120px, calc(100% - 2rem)); margin: 2rem auto; color: var(--muted); text-align: center; position: relative; z-index: 1; }
.empty { padding: 2rem; text-align: center; color: var(--muted); }
.chips { display: flex; gap: .5rem; flex-wrap: wrap; }
.chip { display: inline-flex; align-items: center; gap: .3rem; padding: .5rem .75rem; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.055); color: var(--muted); font-weight: 800; }
.chip:hover { background: var(--panel2); color: var(--text); }
.sidebar-link { display: flex; align-items: center; justify-content: space-between; gap: .6rem; padding: .78rem .85rem; border-radius: 18px; color: var(--muted); font-weight: 850; }
.sidebar-link:hover, .sidebar-link.active { color: var(--text); background: var(--panel2); }
.report-box { display: none; margin-top: .75rem; padding: .75rem; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.045); }
.report-box.open { display: block; }
.bottom-nav { display: none; }
@media (max-width: 1080px) {
  .app-grid { grid-template-columns: minmax(0, 1fr) 300px; }
  .left-rail { display: none; }
  .topbar { grid-template-columns: minmax(180px, 270px) 1fr auto; }
}
@media (max-width: 850px) {
  body { padding-bottom: 92px; }
  .grid, .app-grid { grid-template-columns: 1fr; }
  .right-rail { position: static; }
  .topbar { grid-template-columns: 1fr auto; }
  .top-search { grid-column: 1 / -1; order: 3; width: 100%; }
  .nav-toggle { display: block; border: 1px solid var(--line); background: var(--panel2); color: var(--text); border-radius: 14px; padding: .55rem .75rem; }
  .nav { display: none; position: absolute; left: 1rem; right: 1rem; top: 76px; background: rgba(9,11,22,.97); padding: .75rem; border: 1px solid var(--line); border-radius: 22px; }
  .nav.open { display: grid; }
  .nav a { width: 100%; }
  .brand small { display: none; }
  .profile-head { display: grid; align-items: start; }
  .stat-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .bottom-nav {
    position: fixed; z-index: 60; display: grid; grid-template-columns: repeat(5, 1fr); gap: .25rem;
    left: .65rem; right: .65rem; bottom: calc(.65rem + env(safe-area-inset-bottom));
    padding: .45rem; border: 1px solid var(--line); border-radius: 26px;
    background: rgba(9,11,22,.9); backdrop-filter: blur(20px); box-shadow: 0 20px 70px rgba(0,0,0,.45);
  }
  .bottom-nav a { display: grid; place-items: center; gap: .1rem; color: var(--muted); font-weight: 850; font-size: .75rem; }
  .bottom-nav span { font-size: 1.2rem; }
  .bottom-nav a.active { color: var(--text); }
  .bottom-nav .compose-fab span { width: 46px; height: 46px; margin-top: -24px; display: grid; place-items: center; border-radius: 18px; background: linear-gradient(135deg, var(--accent), var(--accent2)); color: white; box-shadow: 0 16px 32px rgba(6,182,212,.22); }
}
@media (max-width: 520px) {
  .shell { width: min(100% - 1rem, 1180px); margin-top: .75rem; }
  .card { border-radius: 22px; padding: .85rem; }
  .hero { min-height: 460px; }
  .hero h1 { font-size: clamp(2.2rem, 16vw, 4.6rem); }
  .profile-id { display: grid; align-items: start; }
  .avatar.big { width: 96px; height: 96px; }
  .stat-cards { grid-template-columns: 1fr; }
}

/* Phase 3 branding + monetization */
.phase3-bar { border-bottom-color: rgba(255,255,255,.2); }
.phase3-hero { background:
  radial-gradient(circle at 20% 20%, rgba(255,255,255,.15), transparent 15rem),
  radial-gradient(circle at 80% 10%, rgba(6,182,212,.25), transparent 18rem),
  linear-gradient(135deg, rgba(139,92,246,.28), rgba(6,182,212,.13));
}
.mini-hero { min-height: 320px; }
.studio-hero { background: linear-gradient(135deg, rgba(139,92,246,.24), rgba(245,158,11,.12)); }
.verify-badge { display:inline-grid; place-items:center; width:1.15rem; height:1.15rem; border-radius:50%; background:linear-gradient(135deg,var(--accent),var(--accent2)); color:#fff; font-size:.74rem; font-weight:950; vertical-align:middle; }
.tier-badge { display:inline-flex; align-items:center; padding:.12rem .38rem; border-radius:999px; border:1px solid var(--line); font-size:.64rem; letter-spacing:.04em; font-weight:950; vertical-align:middle; }
.tier-badge.creator { color:#a5f3fc; background:rgba(6,182,212,.12); }
.tier-badge.pro { color:#fde68a; background:rgba(245,158,11,.14); }
.feature-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.75rem; margin-top:1rem; }
.feature-grid > div { padding:1rem; border:1px solid var(--line); border-radius:20px; background:rgba(255,255,255,.055); }
.feature-grid strong { display:block; margin-bottom:.35rem; }
.feature-grid span { color:var(--muted); }
.ad-card { display:grid; gap:.45rem; padding:1rem; border:1px solid rgba(255,255,255,.18); border-radius:24px; background:linear-gradient(135deg, rgba(255,255,255,.095), rgba(255,255,255,.04)); color:var(--text); box-shadow:0 20px 55px rgba(0,0,0,.22); }
.ad-card:hover { transform:translateY(-1px); background:rgba(255,255,255,.09); }
.ad-card img { width:100%; max-height:160px; object-fit:cover; border-radius:18px; border:1px solid var(--line); }
.ad-card strong { font-size:1.08rem; }
.ad-card small, .ad-card p { color:var(--muted); margin:0; }
.ad-card em { width:max-content; padding:.25rem .5rem; border-radius:999px; background:rgba(6,182,212,.13); border:1px solid var(--line); font-style:normal; color:#a5f3fc; font-weight:800; }
.empty-ad { text-decoration:none; }
.ad-label { width:max-content; padding:.2rem .5rem; border:1px solid var(--line); border-radius:999px; color:var(--muted); font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; font-weight:900; }
.creator-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.creator-card { position:relative; overflow:hidden; text-align:left; }
.creator-card.preview { padding:1rem; }
.creator-card h2, .creator-card h3 { margin:.4rem 0 .1rem; }
.creator-cover-small { height:120px; margin:-1rem -1rem .5rem; background:linear-gradient(135deg, rgba(139,92,246,.35), rgba(6,182,212,.23)); }
.creator-cover-small img { width:100%; height:100%; object-fit:cover; }
.creator-avatar { margin-top:-54px; border-width:4px; border-color:rgba(255,255,255,.25); }
.creator-mini { margin-top:1rem; padding:.75rem; border-radius:18px; background:rgba(6,182,212,.1); border:1px solid var(--line); display:grid; gap:.25rem; }
.creator-mini span { color:var(--muted); }
.profile-card.theme-neon, .theme-neon { box-shadow:0 0 0 1px rgba(6,182,212,.22), 0 22px 70px rgba(6,182,212,.12); }
.profile-card.theme-gold, .theme-gold { box-shadow:0 0 0 1px rgba(245,158,11,.24), 0 22px 70px rgba(245,158,11,.12); }
.profile-card.theme-forest, .theme-forest { box-shadow:0 0 0 1px rgba(34,197,94,.18), 0 22px 70px rgba(34,197,94,.10); }
.profile-card.theme-studio, .theme-studio { box-shadow:0 0 0 1px rgba(236,72,153,.18), 0 22px 70px rgba(236,72,153,.10); }
.creator-headline { margin:.35rem 0 0; font-weight:850; color:#fff; }
.creator-panel { margin-top:1rem; padding:1rem; border:1px solid var(--line); border-radius:22px; background:linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.035)); display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.price-pill { padding:.55rem .85rem; border-radius:999px; background:rgba(245,158,11,.16); border:1px solid rgba(245,158,11,.35); color:#fde68a; font-weight:950; white-space:nowrap; }
.check-row { display:flex; align-items:center; gap:.4rem; color:var(--muted); font-weight:800; }
.check-row input { width:auto; }
.profile-mini { overflow:hidden; }
.phase3-stat-cards .stat-card { min-height:116px; }
@media (max-width: 1080px) { .creator-grid { grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width: 720px) { .creator-grid, .feature-grid { grid-template-columns:1fr; } .creator-panel { display:grid; } }


/* Phase 4 additions */
.hero.compact{padding:2rem;text-align:left}.hero.compact h1{font-size:clamp(2rem,5vw,4rem);margin:.3rem 0}.mini{font-size:.75rem;padding:.25rem .55rem}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.pricing-card{position:relative;overflow:hidden}.pricing-card.featured{border-color:rgba(139,92,246,.55);box-shadow:0 20px 80px rgba(139,92,246,.18)}.price{font-size:2.2rem;font-weight:950;letter-spacing:-.04em}.price small{font-size:1rem;color:var(--muted)}.post-video{width:100%;max-height:640px;border-radius:20px;background:#000;object-fit:contain}.video-post{border-color:rgba(6,182,212,.35)}.quoted-post{display:block;margin:1rem 0;padding:1rem;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.045);text-decoration:none}.quoted-post p{margin:.35rem 0 0;color:var(--muted)}.group-cover{width:100%;height:150px;object-fit:cover;border-radius:20px;margin-bottom:.75rem}.group-cover.wide{height:230px}.group-card h2{margin:.3rem 0}.group-hero{overflow:hidden}.reels-grid{display:grid;grid-template-columns:minmax(0,760px);justify-content:center;gap:1rem}.two-col{grid-template-columns:minmax(0,1fr) minmax(280px,360px)}.auth-card{background:radial-gradient(circle at 100% 0,rgba(6,182,212,.18),transparent 22rem),var(--card)}.alert.warning{background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.35)}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:.8rem;border-bottom:1px solid var(--line);text-align:left}code{background:rgba(255,255,255,.09);padding:.15rem .38rem;border-radius:.4rem}.check-row{display:flex;align-items:center;gap:.55rem}@media(max-width:900px){.two-col{grid-template-columns:1fr}.group-cover.wide{height:170px}.pricing-grid{grid-template-columns:1fr}.reels-grid{display:block}}

/* Phase 5 launch polish */
.brand-logo{width:44px;height:44px;object-fit:cover;border-radius:14px;border:1px solid var(--line,rgba(255,255,255,.14));box-shadow:0 10px 30px rgba(0,0,0,.25)}
.jumbo{width:96px;height:96px;font-size:3rem;border-radius:28px;display:inline-grid;place-items:center}
.phase5-footer{padding-bottom:5.5rem}.footer-links{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1rem}.footer-links a{color:inherit;text-decoration:none;border:1px solid var(--line,rgba(255,255,255,.14));border-radius:999px;padding:.45rem .75rem;background:rgba(255,255,255,.04)}
.eyebrow{text-transform:uppercase;letter-spacing:.14em;color:var(--muted,#aab0c0);font-size:.78rem;font-weight:900;margin:0 0 .5rem}.phase5-hero{display:grid;grid-template-columns:1.35fr .65fr;gap:1rem;align-items:stretch}.glass-card{background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.04))}.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.three{grid-template-columns:repeat(3,minmax(0,1fr))}.brand-preview{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center}.brand-preview img{width:112px;height:112px;object-fit:cover;border-radius:30px;border:1px solid var(--line,rgba(255,255,255,.14));box-shadow:0 20px 50px rgba(0,0,0,.25)}
.legal-doc{max-width:940px;margin:auto}.legal-doc h1{font-size:clamp(2rem,5vw,3.5rem)}.legal-body{line-height:1.75}.legal-body h1,.legal-body h2,.legal-body h3{margin-top:1.4rem}.legal-body p{color:var(--text,#f6f7fb)}.info{background:rgba(14,165,233,.12)}
.admin-two{grid-template-columns:minmax(240px,.45fr) minmax(0,1fr)}.progress{height:14px;background:rgba(255,255,255,.08);border:1px solid var(--line,rgba(255,255,255,.14));border-radius:999px;overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--accent,#8b5cf6),var(--accent2,#06b6d4));border-radius:inherit}.checklist-row{display:grid;grid-template-columns:auto 1fr;align-items:center;text-align:left}.checklist-row.done{opacity:.68}.checklist-row.done strong{text-decoration:line-through}.mini-check{width:34px;height:34px;border-radius:999px;border:1px solid var(--line,rgba(255,255,255,.14));background:rgba(255,255,255,.08);color:inherit;font-weight:900;cursor:pointer}
.form-row select,.actions select{width:100%;border:1px solid var(--line,rgba(255,255,255,.14));border-radius:16px;background:rgba(255,255,255,.06);color:var(--text,#f6f7fb);padding:.9rem 1rem}.actions select{max-width:180px}.brand-kit h1{font-size:clamp(2.2rem,6vw,4.5rem);letter-spacing:-.05em}
@media(max-width:900px){.phase5-hero,.three,.admin-two{grid-template-columns:1fr}.brand-preview{grid-template-columns:1fr}.phase5-footer{padding-bottom:6rem}}

/* Phase 6 beta launch + growth polish */
.phase6-hero {
  background:
    radial-gradient(circle at 10% 20%, rgba(34,197,94,.22), transparent 18rem),
    radial-gradient(circle at 85% 10%, rgba(139,92,246,.28), transparent 18rem),
    linear-gradient(135deg, rgba(6,182,212,.20), rgba(15,23,42,.92));
}
.copy-box { display:flex; gap:.6rem; align-items:center; padding:.55rem; border:1px solid var(--line); border-radius:20px; background:rgba(255,255,255,.055); }
.copy-box input { flex:1; min-width:0; border:0; background:transparent; color:var(--text); font-weight:800; }
.progress { height:14px; border:1px solid var(--line); border-radius:999px; overflow:hidden; background:rgba(255,255,255,.06); }
.progress.small { height:10px; min-width:130px; }
.progress span { display:block; height:100%; border-radius:999px; background:linear-gradient(135deg,var(--accent),var(--accent2)); }
.roadmap-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.roadmap-card { display:flex; flex-direction:column; gap:.6rem; }
.roadmap-card h2 { margin:.25rem 0 0; }
button[disabled], .btn[disabled] { opacity:.55; cursor:not-allowed; filter:grayscale(.35); }
@media(max-width:900px){ .roadmap-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:620px){ .roadmap-grid { grid-template-columns:1fr; } .copy-box { display:grid; } }

/* Phase 7 real-launch + mobile polish */
.phase7-hero {
  background:
    radial-gradient(circle at 12% 14%, rgba(6,182,212,.30), transparent 17rem),
    radial-gradient(circle at 82% 0%, rgba(245,158,11,.22), transparent 18rem),
    linear-gradient(135deg, rgba(139,92,246,.24), rgba(2,6,23,.95));
  border-color: rgba(255,255,255,.22);
}
.phase7-phone-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.phone-shot { min-height:220px; display:flex; flex-direction:column; justify-content:end; background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.035)); position:relative; overflow:hidden; }
.phone-shot:before { content:""; position:absolute; inset:1rem 1rem auto auto; width:86px; height:150px; border:1px solid rgba(255,255,255,.18); border-radius:24px; background:linear-gradient(180deg,rgba(6,182,212,.24),rgba(139,92,246,.10)); box-shadow:0 20px 60px rgba(0,0,0,.28); }
.phase7-reels { display:grid; grid-template-columns:minmax(0,720px); justify-content:center; gap:1.15rem; }
.phase7-reel-card .post-card { border-radius:32px; overflow:hidden; background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.045)); }
.phase7-reel-card video, .phase7-reel-card .post-video { width:100%; max-height:78vh; object-fit:contain; background:#000; border-radius:24px; }
.check-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.55rem; max-height:360px; overflow:auto; padding:.3rem; border:1px solid var(--line); border-radius:18px; background:rgba(255,255,255,.035); }
.inline-form { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.inline-form select { width:auto; min-width:110px; }
.stat-card.good { border-color:rgba(34,197,94,.32); }
.stat-card.warning { border-color:rgba(245,158,11,.42); }
.stat-card.bad { border-color:rgba(239,68,68,.42); }
[data-push-status] { margin-top:1rem; }
@media (max-width:900px){ .phase7-phone-grid{grid-template-columns:1fr}.check-grid{grid-template-columns:1fr}.phase7-reels{display:block} }
@media (max-width:520px){
  .topbar{padding:.65rem .75rem}.top-search input{min-height:42px}.bottom-nav{left:.45rem;right:.45rem;border-radius:24px}.phase7-reel-card{margin-bottom:1rem}.phase7-reel-card .post-card{border-radius:24px}.footer-links a{font-size:.85rem}
}


/* Phase 8 hardening polish */
.phase8-hardening { border: 1px solid rgba(94,234,212,.35); box-shadow: 0 0 0 1px rgba(94,234,212,.08), 0 18px 60px rgba(0,0,0,.25); }
.code-box, code { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: .6rem; padding: .15rem .35rem; }
.check-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(160px,1fr)); gap:.45rem; max-height: 360px; overflow:auto; padding:.5rem; border:1px solid rgba(255,255,255,.08); border-radius:1rem; }
.warning { border-color: rgba(251,191,36,.4); }


/* Phase 9: Lifeline, Pulse reactions, messenger polish, creator tools */
.pulse-submit { box-shadow: 0 0 0 0 rgba(255,85,145,.45); animation: pulseGlow 2.2s infinite; }
@keyframes pulseGlow { 0% { box-shadow:0 0 0 0 rgba(255,85,145,.45)} 70% { box-shadow:0 0 0 12px rgba(255,85,145,0)} 100% { box-shadow:0 0 0 0 rgba(255,85,145,0)} }
.reaction-strip { display:flex; gap:.35rem; flex-wrap:wrap; margin:.8rem 0 .25rem; min-height:1.6rem; }
.reaction-pill { display:inline-flex; align-items:center; gap:.25rem; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.06); padding:.25rem .55rem; border-radius:999px; font-size:.86rem; }
.pulse-actions { align-items:center; flex-wrap:wrap; }
.reaction-form { position:relative; }
.reaction-main span { display:inline-block; transform-origin:center; }
.reaction-main.reacted { background:linear-gradient(135deg, rgba(255,70,130,.95), rgba(255,158,79,.95)); color:white; border-color:transparent; }
.heart-pulse { animation: heartPulse 1.45s ease-in-out infinite; }
@keyframes heartPulse { 0%,100% { transform:scale(1); filter:drop-shadow(0 0 0 rgba(255,70,130,0)); } 45% { transform:scale(1.13); filter:drop-shadow(0 0 8px rgba(255,70,130,.65)); } }
.reaction-picker { position:absolute; left:0; bottom:calc(100% + .4rem); display:flex; gap:.25rem; padding:.35rem; border-radius:999px; background:rgba(9,12,27,.96); border:1px solid rgba(255,255,255,.14); box-shadow:0 18px 40px rgba(0,0,0,.38); opacity:0; transform:translateY(6px) scale(.95); pointer-events:none; transition:.16s ease; z-index:20; }
.reaction-form:hover .reaction-picker, .reaction-form:focus-within .reaction-picker { opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.reaction-choice { border:0; background:rgba(255,255,255,.08); width:2.25rem; height:2.25rem; border-radius:50%; font-size:1.25rem; cursor:pointer; transition:.15s ease; }
.reaction-choice:hover { transform:translateY(-3px) scale(1.15); background:rgba(255,255,255,.18); }
.phase9-reels { display:grid; grid-template-columns: minmax(0, 760px); justify-content:center; gap:1rem; margin-top:1rem; }
.phase9-reel-card .post { overflow:hidden; border:1px solid rgba(255,255,255,.14); }
.phase9-reels .post-video, .pulse-reel .post-video { width:100%; max-height:76vh; object-fit:contain; background:#05070f; border-radius:1.2rem; }
.phase9-reels-hero { background:radial-gradient(circle at 20% 20%, rgba(255,72,128,.22), transparent 38%), radial-gradient(circle at 80% 10%, rgba(95,118,255,.22), transparent 32%), rgba(255,255,255,.06); }
.messenger-shell { display:grid; grid-template-columns: minmax(260px, 340px) minmax(0,1fr); gap:1rem; align-items:start; }
.messenger-list, .messenger-chat { min-height:70vh; }
.messenger-title { display:flex; align-items:start; justify-content:space-between; gap:1rem; }
.messenger-title h2 { margin:.2rem 0; }
.convo-list { max-height:67vh; overflow:auto; padding-right:.25rem; }
.convo-row { border:1px solid transparent; border-radius:1rem; padding:.55rem; }
.convo-row.active { border-color:rgba(255,255,255,.16); background:rgba(255,255,255,.07); }
.chat-head { display:flex; align-items:center; gap:.75rem; border-bottom:1px solid rgba(255,255,255,.1); padding-bottom:.9rem; margin-bottom:.9rem; }
.chat-head h1 { margin:0; font-size:1.25rem; }
.chat-scroll { max-height:58vh; overflow:auto; display:flex; flex-direction:column; gap:.65rem; padding:.25rem .2rem 1rem; scroll-behavior:smooth; }
.message-row { display:flex; }
.message-row > div { max-width:min(72%, 620px); padding:.7rem .85rem; border-radius:1rem; border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.07); }
.message-row.me { justify-content:flex-end; }
.message-row.me > div { background:linear-gradient(135deg, rgba(80,110,255,.35), rgba(255,80,145,.28)); }
.quick-replies { display:flex; gap:.45rem; flex-wrap:wrap; margin:.65rem 0; }
.chat-compose { display:grid; grid-template-columns: minmax(0,1fr) auto; gap:.65rem; align-items:end; border-top:1px solid rgba(255,255,255,.1); padding-top:.75rem; }
.chat-compose textarea { min-height:54px; max-height:150px; }
.chat-empty { padding:4rem 1rem; text-align:center; }
.phase9-admin-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap:1rem; }
.phase9-readiness-list .note-row { justify-content:space-between; }
.status-dot { width:.75rem; height:.75rem; display:inline-block; border-radius:999px; background:#888; margin-right:.4rem; }
.status-dot.good { background:#31d67b; box-shadow:0 0 12px rgba(49,214,123,.7); }
.status-dot.warn { background:#ffb84d; box-shadow:0 0 12px rgba(255,184,77,.6); }
@media (max-width: 860px) { .messenger-shell { grid-template-columns:1fr; } .messenger-list, .messenger-chat { min-height:auto; } .chat-scroll { max-height:58vh; } .message-row > div { max-width:84%; } }

/* Phase 10.1: fixed compact desktop navigation + controlled mobile drawer */
.phase10-topbar {
  grid-template-columns: minmax(160px, 245px) minmax(190px, 360px) minmax(0, 1fr) auto;
  padding: .55rem clamp(.8rem, 2vw, 1.25rem);
  gap: .55rem;
  overflow: visible;
}
.compact-brand { min-width:0; }
.compact-brand .brand-mark { width: 38px; height: 38px; border-radius: 13px; }
.compact-brand strong { font-size: .95rem; max-width: 170px; }
.compact-brand small { font-size: .66rem; max-width: 160px; }
.compact-search input { height: 36px; min-height:36px; padding: .55rem .85rem; }
.compact-nav { flex-wrap: nowrap; justify-content: flex-end; gap: .12rem; overflow: hidden; min-width: 0; }
.compact-nav a { display:inline-flex; align-items:center; gap:.28rem; padding:.46rem .55rem; font-size:.82rem; line-height:1; white-space:nowrap; max-width:118px; overflow:hidden; text-overflow:ellipsis; }
.compact-nav a span { opacity:.9; font-size:.95rem; }
.pulse-nav-btn { background:linear-gradient(135deg,var(--accent),var(--accent2)) !important; border-color:transparent !important; color:#fff !important; max-width:96px !important; }
.phase10-menu-btn { display:inline-flex; align-items:center; gap:.32rem; border:1px solid var(--line); background:var(--panel2); color:var(--text); border-radius:999px; padding:.48rem .68rem; font-weight:900; white-space:nowrap; position:relative; z-index:95; }
.nav-drawer {
  position: fixed; top: 62px; right: clamp(.65rem, 2vw, 1rem); z-index: 90;
  width: min(360px, calc(100vw - 1rem)); max-height: min(66vh, 560px); overflow:auto;
  display:none; gap:.65rem; padding:.75rem; border:1px solid var(--line); border-radius:20px;
  background: rgba(9,11,22,.985); backdrop-filter: blur(22px); box-shadow:0 24px 70px rgba(0,0,0,.48);
}
.nav-drawer.open { display:grid; }
.drawer-head { display:flex; align-items:center; justify-content:space-between; gap:.7rem; position:sticky; top:-.75rem; background:rgba(9,11,22,.99); padding:.45rem 0; z-index:2; }
.drawer-section { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.32rem; padding:.55rem; border:1px solid rgba(255,255,255,.08); border-radius:16px; background:rgba(255,255,255,.035); }
.drawer-section h3 { grid-column:1/-1; margin:.05rem .2rem .2rem; color:var(--muted); font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; }
.drawer-link { display:flex; align-items:center; gap:.4rem; padding:.55rem .6rem; border-radius:12px; background:rgba(255,255,255,.045); color:var(--text); font-weight:800; font-size:.88rem; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.drawer-link:hover, .drawer-link.active { background:var(--panel2); }
.drawer-search-wrap { display:none; }
.admin-drawer { max-height:220px; overflow:auto; }
.bottom-more { border:0; background:transparent; color:var(--muted); display:grid; place-items:center; gap:.1rem; font-weight:850; font-size:.75rem; padding:0; }
.bottom-more span { font-size:1.2rem; }
.bottom-more:hover, .bottom-more:focus { color:var(--text); }

@media (max-width: 1180px) {
  .phase10-topbar { grid-template-columns:minmax(155px,230px) minmax(0,1fr) auto; }
  .phase10-topbar .top-search { display:none; }
  .compact-nav { display:flex; }
  .compact-nav a { font-size:.78rem; padding:.44rem .48rem; max-width:105px; }
}
@media (max-width: 920px) {
  .phase10-topbar { grid-template-columns:1fr auto; top:0; }
  .compact-nav, .phase10-topbar .top-search { display:none; }
  .phase10-menu-btn span { display:none; }
  .nav-drawer { left:.55rem; right:.55rem; top:64px; width:auto; max-height:calc(100vh - 150px); border-radius:22px; padding:.7rem; }
  .drawer-search-wrap { display:block; }
  .drawer-section { grid-template-columns:1fr 1fr; }
  .admin-drawer { max-height:260px; overflow:auto; }
  body { padding-bottom:94px; }
  .bottom-nav.phase10-bottom-nav { grid-template-columns: repeat(5, 1fr); }
  .bottom-nav.phase10-bottom-nav a, .bottom-nav.phase10-bottom-nav button { min-width:0; }
}
@media (max-width: 430px) {
  .drawer-section { grid-template-columns:1fr; }
  .nav-drawer { max-height:calc(100vh - 142px); }
  .bottom-nav a small, .bottom-nav button small { font-size:.68rem; }
}

/* Phase 10 reaction reliability polish */
.reaction-form.phase10-submitting .reaction-choice { pointer-events:none; opacity:.65; }
.reaction-choice:focus-visible { outline:2px solid var(--accent2); outline-offset:2px; }
.reaction-pill.heart-pulse { display:inline-flex; }

/* Phase 10 profile theme system */
.phase10-profile { --profile-accent:#8b5cf6; position:relative; }
.phase10-profile:before { content:""; position:absolute; inset:0; pointer-events:none; opacity:.6; background:radial-gradient(circle at 15% 12%, color-mix(in srgb, var(--profile-accent) 38%, transparent), transparent 22rem); z-index:0; }
.phase10-profile > * { position:relative; z-index:1; }
.phase10-profile .profile-cover { border-color: color-mix(in srgb, var(--profile-accent) 50%, transparent); background:linear-gradient(135deg, color-mix(in srgb, var(--profile-accent) 62%, #101321), rgba(255,255,255,.06)); }
.phase10-profile .btn:not(.secondary):not(.ghost):not(.danger) { background:linear-gradient(135deg, var(--profile-accent), var(--accent2)); }
.theme-neon { --profile-accent:#06b6d4; }
.theme-gold { --profile-accent:#f59e0b; }
.theme-forest { --profile-accent:#22c55e; }
.theme-studio { --profile-accent:#ec4899; }
.theme-sunset { --profile-accent:#f97316; }
.theme-ocean { --profile-accent:#38bdf8; }
.theme-mono { --profile-accent:#e5e7eb; }
.phase10-profile.theme-neon { background:linear-gradient(135deg, rgba(6,182,212,.16), rgba(139,92,246,.09)), var(--panel); }
.phase10-profile.theme-gold { background:linear-gradient(135deg, rgba(245,158,11,.18), rgba(255,255,255,.045)), var(--panel); }
.phase10-profile.theme-forest { background:linear-gradient(135deg, rgba(34,197,94,.16), rgba(6,95,70,.08)), var(--panel); }
.phase10-profile.theme-studio { background:linear-gradient(135deg, rgba(236,72,153,.18), rgba(15,23,42,.08)), var(--panel); }
.phase10-profile.theme-sunset { background:linear-gradient(135deg, rgba(249,115,22,.20), rgba(236,72,153,.08)), var(--panel); }
.phase10-profile.theme-ocean { background:linear-gradient(135deg, rgba(56,189,248,.18), rgba(14,165,233,.08)), var(--panel); }
.phase10-profile.theme-mono { background:linear-gradient(135deg, rgba(255,255,255,.11), rgba(255,255,255,.035)), var(--panel); }
.phase10-profile.layout-creator .profile-head { align-items:center; }
.phase10-profile.layout-creator .profile-id { align-items:center; }
.phase10-profile.layout-creator .avatar.big { width:132px; height:132px; box-shadow:0 0 0 5px color-mix(in srgb, var(--profile-accent) 32%, transparent); }
.phase10-profile.layout-minimal .profile-cover { min-height:120px; }
.phase10-profile.layout-minimal .profile-cover img { height:150px; filter:saturate(.85); }
.theme-preview-strip { display:flex; gap:.45rem; flex-wrap:wrap; margin:.7rem 0 1rem; }
.theme-swatch { padding:.45rem .65rem; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.06); font-size:.82rem; font-weight:850; }
.theme-swatch.theme-neon { border-color:rgba(6,182,212,.5); }
.theme-swatch.theme-gold { border-color:rgba(245,158,11,.55); }
.theme-swatch.theme-forest { border-color:rgba(34,197,94,.45); }
.theme-swatch.theme-studio { border-color:rgba(236,72,153,.45); }
.theme-swatch.theme-sunset { border-color:rgba(249,115,22,.55); }
.theme-swatch.theme-ocean { border-color:rgba(56,189,248,.5); }
.theme-swatch.theme-mono { border-color:rgba(229,231,235,.45); }

.phase10-dashboard-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1rem; }
.cron-box { word-break:break-all; }

/* Phase 10.1 touch fix: make every reaction available on phones/tablets */
@media (max-width: 700px) {
  .pulse-actions { align-items:flex-start; }
  .reaction-form { display:grid; gap:.35rem; width:100%; }
  .reaction-picker { position:static; opacity:1; transform:none; pointer-events:auto; display:flex; flex-wrap:wrap; width:max-content; max-width:100%; border-radius:18px; }
  .reaction-main { width:max-content; }
}

/* Phase 11 profile media, avatar history, and short Lifeline */
.avatar-history-link { position:relative; display:inline-grid; place-items:center; text-decoration:none; color:var(--text); }
.avatar-history-link img { display:block; }
.avatar-history-link span { position:absolute; bottom:.25rem; left:50%; transform:translateX(-50%); white-space:nowrap; font-size:.68rem; font-weight:900; padding:.25rem .45rem; border-radius:999px; background:rgba(0,0,0,.62); border:1px solid rgba(255,255,255,.18); opacity:0; transition:.18s ease; }
.avatar-history-link:hover span, .avatar-history-link:focus span { opacity:1; }
.phase11-media-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(190px, 1fr)); gap:1rem; }
.phase11-media-card { margin:0; border:1px solid var(--line); border-radius:22px; overflow:hidden; background:rgba(255,255,255,.045); box-shadow:var(--shadow-soft); }
.phase11-media-card img, .phase11-media-card video { width:100%; height:230px; object-fit:cover; display:block; background:#050816; }
.phase11-media-card figcaption { display:grid; gap:.2rem; padding:.75rem; }
.phase11-media-card figcaption span, .phase11-media-card figcaption small { color:var(--muted); }
.phase11-upload-grid { grid-template-columns:1.15fr .85fr; align-items:start; }
.toggle-chip { display:inline-flex; align-items:center; gap:.35rem; padding:.55rem .75rem; border:1px solid var(--line); border-radius:999px; background:rgba(255,255,255,.055); font-weight:800; color:var(--muted); }
.toggle-chip input { width:auto; }
.phase11-short-hero { text-align:center; background:radial-gradient(circle at top, rgba(236,72,153,.18), transparent 35rem), var(--panel); }
.phase11-short-feed { display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 440px)); justify-content:center; gap:1.1rem; margin-top:1rem; }
.phase11-short-card .post, .phase11-short.post { border-radius:30px; background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)), var(--panel); }
.phase11-short-card .media-grid, .phase11-short .media-grid { display:block; }
.phase11-short-card .post-video, .phase11-short .post-video { width:100%; max-height:72vh; aspect-ratio:9/16; object-fit:cover; border-radius:24px; background:#000; }
.phase11-short-card .post-head, .phase11-short .post-head { align-items:center; }
.phase11-media-studio .profile-tabs { padding:0; margin-top:1rem; }
.check-list { color:var(--muted); line-height:1.8; }
@media (max-width: 760px) {
  .phase11-upload-grid { grid-template-columns:1fr; }
  .phase11-short-feed { grid-template-columns:1fr; }
  .phase11-media-card img, .phase11-media-card video { height:210px; }
}

/* Phase 12: shorts, albums, creator polish, launch readiness */
.phase12-short-hero{background:linear-gradient(135deg,rgba(139,92,246,.20),rgba(6,182,212,.10));border:1px solid rgba(255,255,255,.10)}
.phase12-shorts-viewer{display:grid;gap:1.5rem;max-width:780px;margin:1rem auto 3rem;scroll-snap-type:y proximity}
.phase12-short-player{scroll-snap-align:start;border-radius:28px;overflow:hidden;background:#050816;border:1px solid rgba(255,255,255,.12);box-shadow:0 24px 80px rgba(0,0,0,.35)}
.phase12-short-stage{position:relative;min-height:min(80vh,840px);display:grid;place-items:center;background:radial-gradient(circle at center,rgba(139,92,246,.20),#050816 58%)}
.phase12-short-stage video{width:100%;height:min(80vh,840px);object-fit:contain;background:#000;display:block}
.phase12-short-overlay{position:absolute;inset:auto 0 0 0;display:flex;justify-content:space-between;gap:1rem;align-items:flex-end;padding:5rem 1rem 1rem;background:linear-gradient(transparent,rgba(0,0,0,.82));color:#fff;pointer-events:none}
.phase12-short-overlay a,.phase12-short-overlay button,.phase12-short-overlay form{pointer-events:auto}.creator-chip{display:inline-flex;align-items:center;gap:.45rem;color:#fff;text-decoration:none;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);padding:.35rem .6rem;border-radius:999px;backdrop-filter:blur(14px)}
.phase12-short-actions{display:grid;gap:.6rem;justify-items:center}.short-action-btn{min-width:54px;min-height:54px;border-radius:18px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;text-decoration:none;font-size:1.35rem;box-shadow:0 12px 32px rgba(0,0,0,.25)}.short-action-btn small{font-size:.68rem;opacity:.9}.reaction-picker.vertical{right:62px;bottom:0;left:auto;display:none}.short-reaction:hover .reaction-picker,.short-reaction:focus-within .reaction-picker{display:flex}
.phase12-album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem}.phase12-album-card{display:block;min-height:230px;border-radius:24px;overflow:hidden;position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);text-decoration:none;color:inherit;box-shadow:0 14px 40px rgba(0,0,0,.18);transition:transform .18s ease,border-color .18s ease}.phase12-album-card:hover{transform:translateY(-3px);border-color:rgba(139,92,246,.45)}.phase12-album-card img,.album-placeholder{width:100%;height:170px;object-fit:cover;display:grid;place-items:center;font-size:3rem;background:linear-gradient(135deg,rgba(139,92,246,.2),rgba(6,182,212,.12))}.phase12-album-card span{display:block;padding:.85rem}.phase12-album-card small{display:block;color:var(--muted,#9ca3af);margin-top:.2rem}.phase12-album-head,.phase12-albums-hero{background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(139,92,246,.10))}.phase12-album-items .phase11-media-card a{display:block;color:inherit;text-decoration:none}.phase12-album-tools{grid-template-columns:minmax(260px,.8fr) minmax(320px,1.2fr)}
.phase12-media-detail{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(310px,.8fr);gap:1rem;align-items:start}.phase12-media-viewer{padding:.5rem;background:#020617}.phase12-media-viewer img,.phase12-media-viewer video{width:100%;max-height:82vh;object-fit:contain;border-radius:20px;background:#000}.phase12-media-side{position:sticky;top:88px}.phase12-media-open{position:relative;display:block;color:inherit;text-decoration:none}.phase12-media-open span{position:absolute;right:.6rem;bottom:.6rem;background:rgba(0,0,0,.66);color:#fff;border-radius:999px;padding:.2rem .55rem;font-size:.78rem}.comment{display:flex;gap:.7rem;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.08)}.comment p{margin:.2rem 0}.comment-form textarea{min-height:90px}.phase12-media-mod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:1rem}.phase12-mod-preview{height:190px;border-radius:18px;overflow:hidden;background:#000}.phase12-mod-preview img,.phase12-mod-preview video{width:100%;height:100%;object-fit:cover}.phase12-creator-link-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.7rem;margin-top:.8rem}.profile-link-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:1rem 0}.phase12-creator-link{display:flex;align-items:center;gap:.65rem;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);border-radius:18px;padding:.85rem 1rem;text-decoration:none;color:inherit}.phase12-creator-link span{font-size:1.25rem}.phase12-creator-link:hover{border-color:rgba(139,92,246,.45);transform:translateY(-1px)}.phase12-creator-links-head{background:linear-gradient(135deg,rgba(236,72,153,.16),rgba(139,92,246,.12))}.responsive-table{overflow:auto}.responsive-table table{width:100%;border-collapse:collapse}.responsive-table th,.responsive-table td{padding:.7rem;border-bottom:1px solid rgba(255,255,255,.08);text-align:left}.check{display:flex;gap:.5rem;align-items:center;margin:.7rem 0}
@media (max-width:800px){.phase12-media-detail{grid-template-columns:1fr}.phase12-media-side{position:static}.phase12-short-stage,.phase12-short-stage video{height:calc(100vh - 150px);min-height:560px}.phase12-short-overlay{padding:5rem .75rem .75rem}.phase12-album-tools{grid-template-columns:1fr}.phase12-shorts-viewer{margin-left:-.4rem;margin-right:-.4rem}.phase12-short-player{border-radius:20px}}

/* Phase 12 upload/profile-photo hotfix */
.profile-photo-history-card { overflow: hidden; }
.photo-history-count { display:flex; align-items:baseline; gap:.35rem; color:var(--muted); margin-bottom:.75rem; }
.photo-history-count strong { color:var(--text); font-size:1.4rem; }
.profile-photo-thumb-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(78px, 1fr));
  gap:7px;
}
.profile-photo-thumb {
  position:relative;
  display:block;
  aspect-ratio:1 / 1;
  overflow:hidden;
  border-radius:10px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);
  box-shadow:0 6px 16px rgba(0,0,0,.18);
}
.profile-photo-thumb img {
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  transition:transform .18s ease, filter .18s ease;
}
.profile-photo-thumb:hover img { transform:scale(1.045); filter:brightness(1.08); }
.profile-photo-thumb.current { outline:2px solid var(--accent); outline-offset:2px; }
.profile-photo-thumb span {
  position:absolute;
  left:5px;
  bottom:5px;
  font-size:.62rem;
  padding:.18rem .35rem;
  border-radius:999px;
  color:#fff;
  background:rgba(0,0,0,.68);
  backdrop-filter:blur(6px);
}
@media (min-width: 760px) {
  .profile-photo-thumb-grid { grid-template-columns:repeat(auto-fill, minmax(92px, 1fr)); gap:8px; }
}
@media (max-width: 520px) {
  .profile-photo-thumb-grid { grid-template-columns:repeat(4, minmax(0, 1fr)); gap:5px; }
  .profile-photo-thumb { border-radius:8px; }
}

/* Large video upload status */
.upload-status {
  display:none;
  width:100%;
  margin-top:.65rem;
  padding:.7rem .85rem;
  border-radius:14px;
  background:rgba(99,102,241,.12);
  border:1px solid rgba(99,102,241,.25);
  color:var(--text, #eef2ff);
  font-size:.9rem;
}


/* Phase 13: thumbnails, trending, launch polish */
.phase13-trending-hero { overflow:hidden; position:relative; }
.phase13-trending-hero:after { content:""; position:absolute; inset:auto -8rem -8rem auto; width:18rem; height:18rem; border-radius:999px; background:rgba(139,92,246,.18); filter:blur(12px); pointer-events:none; }
.trending-layout { display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:1rem; align-items:start; }
.phase13-video-thumb { position:relative; display:block; overflow:hidden; border-radius:1rem; background:#0f172a; }
.phase13-video-thumb img { width:100%; aspect-ratio:16/9; object-fit:cover; display:block; }
.phase13-video-thumb .play-badge { position:absolute; inset:50% auto auto 50%; transform:translate(-50%,-50%); width:3.2rem; height:3.2rem; display:grid; place-items:center; border-radius:999px; background:rgba(255,255,255,.88); color:#111827; box-shadow:0 12px 30px rgba(0,0,0,.35); }
.tiny-thumb { width:64px; height:44px; object-fit:cover; border-radius:.65rem; background:#111827; }
.user-row.compact { display:flex; align-items:center; gap:.65rem; padding:.55rem 0; text-decoration:none; }
.user-row.compact span { display:grid; gap:.1rem; }
.media-report-box select, .media-report-box input { width:100%; margin:.25rem 0; }
.phase12-mod-preview img, .phase12-mod-preview video { aspect-ratio:16/10; object-fit:cover; }
.table-wrap { overflow-x:auto; }
.table-wrap table { width:100%; border-collapse:collapse; }
.table-wrap th, .table-wrap td { padding:.65rem; border-bottom:1px solid rgba(255,255,255,.08); text-align:left; }
@media (max-width: 900px) { .trending-layout { grid-template-columns:1fr; } .trending-layout .right-rail { display:block; } }

/* Phase 14: notifications, search, SEO profiles, creator payout polish */
.phase14-hero-card { background: linear-gradient(135deg, rgba(139,92,246,.18), rgba(6,182,212,.10)), var(--panel); }
.phase14-split-head { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.phase14-filterbar { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1rem; }
.chip.active { background: linear-gradient(135deg, var(--accent), var(--accent2)); color:#fff; border-color:transparent; }
.phase14-notification-list { display:grid; gap:.75rem; }
.phase14-note { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.85rem; }
.phase14-note.unread { border-color: rgba(6,182,212,.45); background: rgba(6,182,212,.10); }
.phase14-note-main { display:flex; align-items:center; gap:.75rem; min-width:0; flex:1; }
.phase14-note-icon { width:42px; height:42px; display:grid; place-items:center; border-radius:16px; background: var(--panel2); border:1px solid var(--line); font-weight:950; flex:0 0 auto; }
.phase14-search-form { display:grid; grid-template-columns:minmax(0,1fr) 180px auto; gap:.65rem; margin-top:1rem; }
.phase14-user-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:.75rem; }
.phase14-user-card { display:grid; gap:.4rem; align-content:start; padding:1rem; border:1px solid var(--line); border-radius:22px; background:rgba(255,255,255,.05); min-height:170px; }
.phase14-user-card:hover { background:rgba(255,255,255,.08); transform:translateY(-1px); }
.phase14-media-results { grid-template-columns:repeat(4,minmax(0,1fr)); }
.phase14-public-profile { padding:0; overflow:hidden; }
.phase14-public-cover { min-height:260px; background:linear-gradient(135deg, rgba(139,92,246,.42), rgba(6,182,212,.24)); border-bottom:1px solid var(--line); }
.phase14-public-cover img { width:100%; height:310px; object-fit:cover; }
.phase14-public-head { display:flex; gap:1rem; align-items:flex-end; padding:0 1rem 1rem; margin-top:-58px; }
.phase14-public-head .avatar.big { box-shadow:0 18px 45px rgba(0,0,0,.35); }
.phase14-admin-mini-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:.75rem; }
@media (max-width: 850px) {
  .phase14-search-form { grid-template-columns:1fr; }
  .phase14-user-grid, .phase14-media-results, .phase14-admin-mini-grid { grid-template-columns:1fr 1fr; }
  .phase14-note { align-items:flex-start; }
  .phase14-note-main { align-items:flex-start; }
}
@media (max-width: 520px) {
  .phase14-user-grid, .phase14-media-results, .phase14-admin-mini-grid { grid-template-columns:1fr; }
  .phase14-public-head { display:grid; align-items:start; }
  .phase14-note { display:grid; }
}


/* Phase 15 launch polish */
.phase15-hero-card{background:linear-gradient(135deg,rgba(14,165,233,.18),rgba(139,92,246,.16)),rgba(255,255,255,.08)}
.progress-bar{height:12px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#22c55e,#38bdf8,#8b5cf6)}
.onboarding-row{align-items:flex-start}.onboarding-check{width:36px;height:36px;border-radius:999px;background:rgba(255,255,255,.10);display:grid;place-items:center;font-weight:900;border:1px solid rgba(255,255,255,.18)}.onboarding-check.done{background:rgba(34,197,94,.25);color:#bbf7d0}.onboarding-check.skip{background:rgba(245,158,11,.22);color:#fde68a}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.pricing-card{border:1px solid rgba(255,255,255,.14);border-radius:22px;padding:1rem;background:rgba(255,255,255,.07)}.pricing-card strong{font-size:1.7rem;display:block;margin:.35rem 0}
.bar-chart{height:260px;display:flex;align-items:flex-end;gap:.55rem;padding:1rem;border:1px solid rgba(255,255,255,.12);border-radius:20px;background:rgba(0,0,0,.13);overflow-x:auto}.bar-wrap{height:100%;min-width:42px;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:.4rem}.bar{width:24px;min-height:4px;border-radius:999px 999px 4px 4px;background:linear-gradient(180deg,#38bdf8,#8b5cf6)}.bar-wrap small{font-size:.72rem;text-align:center;color:var(--muted,#aab0c0)}
.compact-form{gap:.45rem}.compact-form input,.compact-form select{min-width:130px}.status-passed,.status-approved,.status-live,.status-completed,.status-sent{background:rgba(34,197,94,.18)!important}.status-failed,.status-rejected,.status-deleted{background:rgba(239,68,68,.18)!important}.status-needs_review,.status-submitted,.status-new,.status-queued{background:rgba(245,158,11,.18)!important}
@media(max-width:720px){.pricing-grid{grid-template-columns:1fr}.bar-chart{height:220px}.compact-form{display:grid}.compact-form input,.compact-form select{width:100%;min-width:0}}


/* Phase 15.1: cleaner header - dropdown menu only, no bulky top link row */
.phase10-topbar {
  grid-template-columns: minmax(160px, 260px) minmax(220px, 520px) auto;
  gap: .7rem;
}
.compact-nav { display: none !important; }
.phase10-menu-btn { justify-self: end; }
@media (max-width: 920px) {
  .phase10-topbar { grid-template-columns: 1fr auto; }
  .phase10-topbar .top-search { display: none; }
}
@media (min-width: 921px) {
  .phase10-menu-btn span { display: inline; }
}

/* Phase 16 final polish + launch-control UI */
.phase16-topbar{grid-template-columns:minmax(160px,260px) minmax(220px,1fr) auto auto;gap:.65rem;padding:.58rem clamp(.8rem,2vw,1.25rem)}
.phase16-status-pill{display:inline-flex;align-items:center;gap:.45rem;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.075);border-radius:999px;padding:.42rem .62rem;font-size:.78rem;font-weight:900;color:var(--text);white-space:nowrap}.phase16-status-pill strong{background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:999px;padding:.16rem .38rem;color:white}.launch-mode-maintenance .phase16-status-pill span{color:#fde68a}
.phase16-drawer{width:min(760px,calc(100vw - 1.2rem));max-height:min(78vh,760px);right:clamp(.65rem,2vw,1.3rem);grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}.phase16-drawer.open{display:grid}.phase16-drawer .drawer-head,.phase16-drawer .drawer-search-wrap{grid-column:1/-1}.drawer-head small{display:block;color:var(--muted);font-size:.76rem;margin-top:.1rem}.phase16-section{grid-template-columns:repeat(2,minmax(0,1fr));align-self:start}.phase16-section h3{font-size:.7rem}.phase16-section .drawer-link{gap:.52rem;min-height:42px}.phase16-section .drawer-link span{width:26px;height:26px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.07);flex:0 0 auto}.phase16-section .drawer-link em{font-style:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.phase16-admin-section{grid-column:1/-1;grid-template-columns:repeat(4,minmax(0,1fr));max-height:300px}.phase16-drawer-search input{min-height:42px}.phase16-admin-banner{position:relative;z-index:2;width:min(1180px,calc(100% - 2rem));margin:.85rem auto 0;padding:.75rem 1rem;border-radius:18px;background:rgba(245,158,11,.16);border:1px solid rgba(245,158,11,.28);color:#fde68a}.phase16-admin-banner a{text-decoration:underline;color:#fff}
.phase16-hero{background:linear-gradient(135deg,rgba(34,197,94,.14),rgba(6,182,212,.12),rgba(139,92,246,.16)),rgba(255,255,255,.08)}.phase16-score-ring{width:116px;height:116px;border-radius:999px;display:grid;place-items:center;background:conic-gradient(var(--accent2) calc(var(--score,0)*1%),rgba(255,255,255,.12) 0);position:relative}.phase16-score-ring:after{content:"";position:absolute;inset:10px;border-radius:999px;background:#101325;border:1px solid rgba(255,255,255,.1)}.phase16-score-ring strong{position:relative;z-index:1;font-size:1.7rem}.phase16-check-list{display:grid;gap:.65rem}.phase16-check{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;padding:.85rem;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:rgba(255,255,255,.05)}.phase16-check.good{background:rgba(34,197,94,.10)}.phase16-check.bad.high{background:rgba(239,68,68,.13)}.phase16-check.bad.normal{background:rgba(245,158,11,.11)}.phase16-check .status{font-weight:950;white-space:nowrap}.phase16-log-box{white-space:pre-wrap;overflow:auto;max-height:62vh;padding:1rem;border-radius:18px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.12);font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:.86rem;line-height:1.45}.phase16-launch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1rem}.phase16-public-profile{overflow:hidden}.phase16-public-profile .phase14-public-cover{min-height:260px;background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.18),transparent 18rem),linear-gradient(135deg,rgba(139,92,246,.36),rgba(6,182,212,.23));border-radius:24px}.phase16-public-profile .phase14-public-head{display:grid;grid-template-columns:auto minmax(0,1fr);gap:1rem;align-items:end;margin-top:-56px;padding:0 1rem 1rem}.phase16-public-profile .avatar.big{width:120px;height:120px;border:4px solid rgba(12,15,30,.95);box-shadow:0 18px 45px rgba(0,0,0,.32)}.phase16-profile-stats{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.55rem}.phase16-profile-stats span{padding:.45rem .65rem;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);font-weight:850}.phase16-admin-tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:.75rem}.phase16-admin-tools-grid a{display:block;padding:1rem;border-radius:20px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);font-weight:900}.phase16-admin-tools-grid a span{display:block;margin-top:.25rem;color:var(--muted);font-weight:650;font-size:.88rem}
@media(max-width:1040px){.phase16-topbar{grid-template-columns:minmax(150px,240px) minmax(0,1fr) auto}.phase16-status-pill{display:none}.phase16-drawer{grid-template-columns:1fr;width:min(520px,calc(100vw - 1.1rem))}.phase16-admin-section{grid-template-columns:repeat(2,minmax(0,1fr));max-height:320px}}
@media(max-width:920px){.phase16-topbar{grid-template-columns:1fr auto}.phase16-drawer{left:.55rem;right:.55rem;top:64px;width:auto;max-height:calc(100dvh - 148px);padding:.7rem}.phase16-section{grid-template-columns:1fr 1fr}.phase16-admin-section{grid-template-columns:1fr 1fr}.phase16-public-profile .phase14-public-head{grid-template-columns:1fr;text-align:center;justify-items:center}.phase16-profile-stats{justify-content:center}.shell.phase16-shell{width:min(100% - 1rem,1180px)}}
@media(max-width:480px){.phase16-section,.phase16-admin-section{grid-template-columns:1fr}.phase16-drawer{max-height:calc(100dvh - 136px)}.phase16-section .drawer-link{min-height:40px}.phase16-search{display:none}.phase16-check{display:grid}.phase16-public-profile .avatar.big{width:104px;height:104px}.phase16-admin-banner{width:calc(100% - 1rem);font-size:.9rem}}

/* Phase 17 final beta launch polish */
.phase17-hero{background:linear-gradient(135deg,rgba(99,102,241,.18),rgba(16,185,129,.10));border-color:rgba(255,255,255,.14)}
.phase17-score span{display:block;font-size:.75rem;color:var(--muted,#8b95a7);margin-top:-.35rem}
.phase17-bug-row{padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.phase17-bug-row:last-child{border-bottom:0}.priority-p0{background:rgba(239,68,68,.22)!important}.priority-p1{background:rgba(249,115,22,.22)!important}.priority-p2{background:rgba(59,130,246,.18)!important}.priority-p3{background:rgba(148,163,184,.18)!important}
.bug-triage-form{min-width:230px}.phase17-feedback-form textarea{resize:vertical}.phase17-mobile-polish .drawer-link em{font-style:normal}
@media (max-width:720px){.phase16-drawer{width:min(92vw,390px)}.phase16-section .drawer-link{min-height:44px}.phase17-hero .actions{display:grid;grid-template-columns:1fr}.phase17-hero input{width:100%}.bug-triage-form{min-width:0}.table-wrap table{font-size:.9rem}}
@media (min-width:721px){.phase16-drawer{max-width:760px}.phase16-admin-section{max-height:360px;overflow:auto;padding-right:.25rem}.phase16-admin-section::-webkit-scrollbar{width:8px}.phase16-admin-section::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:99px}}


/* Phase 17.1 hotfix: stable reaction picker for desktop hover and mobile tap */
.reaction-form{position:relative; isolation:isolate;}
.reaction-picker{bottom:100%; margin-bottom:0; z-index:9999;}
.reaction-picker::after{content:""; position:absolute; left:0; right:0; bottom:-14px; height:14px; background:transparent;}
.reaction-form:hover .reaction-picker,
.reaction-form:focus-within .reaction-picker,
.reaction-form.picker-open .reaction-picker{opacity:1; transform:translateY(0) scale(1); pointer-events:auto;}
.reaction-choice{touch-action:manipulation; -webkit-tap-highlight-color:transparent;}
.reaction-main{touch-action:manipulation;}
.reaction-form.picker-open .reaction-main{box-shadow:0 0 0 3px rgba(255,255,255,.12);}
.short-reaction{position:relative;}
.reaction-picker.vertical{position:absolute; right:66px; bottom:0; left:auto; opacity:0; transform:translateX(8px) scale(.96); pointer-events:none; display:flex; flex-wrap:wrap; min-width:220px; max-width:min(72vw,320px); border-radius:20px;}
.short-reaction:hover .reaction-picker.vertical,
.short-reaction:focus-within .reaction-picker.vertical,
.short-reaction.picker-open .reaction-picker.vertical{opacity:1; transform:translateX(0) scale(1); pointer-events:auto; display:flex;}
@media (hover:none), (max-width:700px){
  .reaction-form{display:inline-grid; width:auto; max-width:100%;}
  .pulse-actions .reaction-form{width:auto;}
  .reaction-picker{position:absolute; left:0; bottom:100%; margin-bottom:0; opacity:0; transform:translateY(6px) scale(.96); pointer-events:none; width:max-content; max-width:min(92vw,360px); border-radius:20px; padding:.45rem; gap:.35rem;}
  .reaction-form.picker-open .reaction-picker{opacity:1; transform:translateY(0) scale(1); pointer-events:auto;}
  .reaction-picker.vertical{left:auto; right:64px; bottom:0; max-width:min(76vw,340px);}
  .reaction-choice{width:2.55rem; height:2.55rem; font-size:1.35rem;}
}


/* Phase 18 reaction picker: no hover gap, mobile tap safe, AJAX loading state */
.reaction-form { position:relative; isolation:isolate; }
.reaction-picker { opacity:0; pointer-events:none; transform:translateY(8px) scale(.96); transition:opacity .14s ease, transform .14s ease; z-index:10050; }
.reaction-form.picker-open .reaction-picker,
.reaction-form:focus-within .reaction-picker { opacity:1 !important; pointer-events:auto !important; transform:translateY(0) scale(1) !important; display:flex !important; }
.reaction-form:hover .reaction-picker { opacity:1; pointer-events:auto; transform:translateY(0) scale(1); }
.reaction-choice { touch-action:manipulation; -webkit-tap-highlight-color:transparent; cursor:pointer; }
.reaction-main.is-loading { opacity:.7; cursor:progress; }
.reaction-form.phase18-submitting .reaction-choice { pointer-events:none; opacity:.65; }
@media (hover:none) {
  .reaction-form:hover .reaction-picker { opacity:0; pointer-events:none; transform:translateY(8px) scale(.96); }
  .reaction-form.picker-open .reaction-picker { opacity:1 !important; pointer-events:auto !important; transform:translateY(0) scale(1) !important; }
}
.reaction-picker.vertical { display:flex !important; }
.short-reaction.picker-open .reaction-picker.vertical,
.reaction-form.picker-open .reaction-picker.vertical { opacity:1 !important; pointer-events:auto !important; transform:translateX(0) scale(1) !important; }


/* Phase 19 live chat polish */
.live-messenger { align-items: stretch; }
.live-chat-panel { display:flex; flex-direction:column; min-height:72vh; overflow:hidden; }
.live-chat-scroll { flex:1; min-height:360px; max-height:70vh; overflow:auto; padding:16px; border-radius:22px; background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)); border:1px solid rgba(255,255,255,.08); }
.live-message { display:flex; gap:8px; margin:9px 0; align-items:flex-end; }
.live-message.me { justify-content:flex-end; }
.live-message.them { justify-content:flex-start; }
.message-bubble { max-width:min(72%, 560px); padding:11px 13px; border-radius:20px; border:1px solid rgba(255,255,255,.1); box-shadow:0 10px 22px rgba(0,0,0,.12); overflow:hidden; }
.live-message.me .message-bubble { border-bottom-right-radius:7px; background:linear-gradient(135deg, rgba(118,92,255,.95), rgba(31,193,255,.82)); color:#fff; }
.live-message.me .muted { color:rgba(255,255,255,.74); }
.live-message.them .message-bubble { border-bottom-left-radius:7px; background:rgba(255,255,255,.08); }
.chat-avatar { width:28px; height:28px; }
.chat-attachment-image { display:block; max-width:240px; max-height:260px; width:auto; height:auto; border-radius:16px; margin-top:8px; object-fit:cover; }
.typing-indicator { padding:7px 14px; font-size:.9rem; color:var(--muted); }
.typing-indicator::after { content:' '; display:inline-block; width:1.5em; text-align:left; animation:typingDots 1.1s infinite steps(4); }
@keyframes typingDots { 0%{content:''} 25%{content:'.'} 50%{content:'..'} 75%,100%{content:'...'} }
.live-chat-compose { display:grid; grid-template-columns:auto 1fr auto; gap:8px; align-items:end; padding-top:12px; }
.live-chat-compose textarea { min-height:44px; max-height:140px; resize:none; border-radius:18px; }
.chat-attach input { display:none; }
.chat-attach span { display:flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:16px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.07); cursor:pointer; }
.online-dot { display:inline-block; width:8px; height:8px; border-radius:999px; background:#2eea75; margin-right:6px; box-shadow:0 0 0 4px rgba(46,234,117,.12); }
.live-chat-note { margin-top:6px; }
@media (max-width: 760px) {
  .messenger-shell { grid-template-columns:1fr; }
  .messenger-list { max-height:210px; overflow:auto; }
  .live-chat-panel { min-height:68vh; }
  .live-chat-scroll { max-height:56vh; min-height:310px; padding:10px; }
  .message-bubble { max-width:84%; }
  .live-chat-compose { grid-template-columns:auto 1fr auto; position:sticky; bottom:0; background:var(--card, #111827); padding:10px 0 2px; }
  .chat-attachment-image { max-width:190px; max-height:220px; }
}


/* Phase 20 */
.comment-thread-list { display:flex; flex-direction:column; gap:.75rem; }
.comment-thread-item { display:flex; gap:.7rem; margin-left:calc(var(--comment-depth,0) * 1.35rem); align-items:flex-start; }
.comment-thread-item.is-reply { border-left:1px solid var(--line); padding-left:.75rem; }
.comment-body { flex:1; min-width:0; }
.comment-bubble { background:var(--panel); border:1px solid var(--line); border-radius:18px; padding:.75rem .9rem; }
.comment-actions { display:flex; align-items:center; flex-wrap:wrap; gap:.45rem; margin:.25rem 0 .45rem .25rem; }
.comment-link-btn, .comment-react-toggle { background:transparent; color:var(--muted); border:0; font-weight:800; cursor:pointer; padding:.2rem .35rem; border-radius:999px; }
.comment-link-btn:hover, .comment-react-toggle:hover, .comment-reaction-form.open .comment-react-toggle { color:var(--text); background:var(--panel2); }
.comment-reaction-form { position:relative; }
.comment-reaction-picker { position:absolute; left:0; bottom:115%; display:none; gap:.25rem; background:rgba(12,16,32,.98); border:1px solid var(--line); border-radius:999px; padding:.35rem; box-shadow:0 18px 45px rgba(0,0,0,.35); z-index:40; }
.comment-reaction-form.open .comment-reaction-picker { display:flex; }
.comment-reaction-picker button, .message-reaction-picker button { border:0; background:transparent; font-size:1.2rem; cursor:pointer; border-radius:999px; padding:.2rem .3rem; transition:transform .12s ease, background .12s ease; }
.comment-reaction-picker button:hover, .message-reaction-picker button:hover { transform:translateY(-3px) scale(1.14); background:var(--panel2); }
.comment-reply-box { display:none; gap:.5rem; align-items:flex-end; margin:.5rem 0; }
.comment-reply-box.open { display:flex; }
.comment-reply-box textarea { min-height:44px; }
.comment-reaction-summary { display:flex; gap:.25rem; flex-wrap:wrap; }
.reaction-pill.mini { font-size:.78rem; padding:.1rem .35rem; }
.message-bubble { position:relative; }
.message-reactor { display:inline-flex; position:relative; margin-left:.3rem; vertical-align:middle; }
.message-react-toggle { border:1px solid var(--line); background:var(--panel); color:var(--text); border-radius:999px; width:28px; height:28px; cursor:pointer; line-height:1; }
.message-reaction-picker { position:absolute; right:0; bottom:115%; display:none; background:rgba(12,16,32,.98); border:1px solid var(--line); border-radius:999px; padding:.3rem; gap:.15rem; z-index:60; box-shadow:0 18px 45px rgba(0,0,0,.35); }
.message-reactor.open .message-reaction-picker { display:flex; }
.message-reaction-summary { display:inline-flex; gap:.2rem; flex-wrap:wrap; margin-top:.25rem; }
.message-reaction-pill { font-size:.78rem; background:var(--panel2); border:1px solid var(--line); border-radius:999px; padding:.08rem .32rem; }
.profile-info-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:.6rem; margin:.85rem 0; }
.profile-info-card { border:1px solid var(--line); background:var(--panel); border-radius:18px; padding:.75rem; }
.profile-info-card span { font-size:1.15rem; }
.profile-info-card strong { display:block; margin:.15rem 0; }
.profile-info-card p { margin:0; color:var(--muted); }
.phase20-avatar-preview { width:min(280px,100%); aspect-ratio:1/1; object-fit:cover; border-radius:32px; border:1px solid var(--line); box-shadow:0 20px 60px rgba(0,0,0,.35); }
.phase20-effect-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:.6rem; }
.phase20-effect-grid label { border:1px solid var(--line); background:var(--panel); padding:.85rem; border-radius:18px; cursor:pointer; }
.phase20-effect-grid input { margin-right:.45rem; }
@media (max-width:680px){ .comment-thread-item{margin-left:calc(var(--comment-depth,0) * .75rem)} .comment-reply-box.open{display:block}.comment-reply-box button{margin-top:.4rem}.message-reaction-picker{right:auto;left:0}.profile-info-grid{grid-template-columns:1fr} }
