:root{
  --bg:#f6f7fb;
  --card:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --border:#e5e7eb;
  --primary:#ff2e63;
  --primary-2:#fe206d;
  --dark:#111827;
  --shadow:0 16px 40px rgba(17,24,39,.08);
  --radius:16px;
}

*{box-sizing:border-box}
html,body{margin:0}
body{min-height:100vh;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);padding-bottom:64px}
@media(min-width:640px){body{padding-bottom:0}}
a{color:inherit}

/* Legacy helpers */
.button1{background:var(--primary);color:#fff;border:0;border-radius:12px;padding:10px 14px;font-weight:800;cursor:pointer}
.button2{background:#f3f4f6;border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-weight:700;color:var(--text);cursor:pointer}

.ws-shell{min-height:100%;display:flex;flex-direction:column}
.ws-topbar{height:64px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 18px;gap:12px;position:sticky;top:0;z-index:100}
.ws-brand{display:flex;align-items:center;gap:10px;font-weight:900;text-decoration:none;color:inherit}
.ws-logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#cc0033);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;box-shadow:0 4px 12px rgba(255,46,99,.3)}
.ws-brand-name{font-size:16px;color:#111827}
.ws-brand:hover{text-decoration:none}
.ws-top-actions{display:flex;align-items:center;gap:10px}
.ws-user-pill{display:flex;align-items:center;gap:8px;background:#f3f4f6;border:1px solid #eef0f4;border-radius:999px;padding:7px 12px;font-size:13px;font-weight:600}
.ws-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;display:inline-block;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.4)}50%{box-shadow:0 0 0 6px rgba(34,197,94,0)}}
.ws-link{font-size:13px;color:#374151;text-decoration:none;font-weight:700}
.ws-link:hover{color:var(--primary)}

.ws-btn{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:12px;padding:9px 14px;font-weight:800;cursor:pointer;transition:all .15s}
.ws-btn:hover{filter:brightness(.97)}
.ws-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}
.ws-btn-primary:hover{background:#e6194d}
.ws-btn-dark{background:var(--dark);border-color:var(--dark);color:#fff}
.ws-btn-dark:hover{background:#1f2937}
.ws-btn-block{width:100%;display:inline-flex;justify-content:center;align-items:center;text-decoration:none}

/* Layout */
.ws-layout{width:min(1180px,100%);margin:0 auto;display:grid;grid-template-columns:250px 1fr 290px;gap:18px;padding:18px}
.ws-sidebar,.ws-rightbar{min-height:0;position:sticky;top:82px;max-height:calc(100vh - 100px);overflow-y:auto;align-self:start}
.ws-sidebar::-webkit-scrollbar,.ws-rightbar::-webkit-scrollbar{width:4px}
.ws-sidebar::-webkit-scrollbar-thumb,.ws-rightbar::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:4px}
.ws-main{min-height:0}

.ws-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}

/* Premium card */
.ws-premium-card{padding:18px;color:#fff;border:0;background:linear-gradient(135deg,#111827 0%,#22102d 60%,#2b0b1f 100%)}
.ws-premium-active{background:linear-gradient(135deg,#0f4c35,#065f46)}
.ws-premium-title{font-weight:900;font-size:14px;margin-bottom:4px}
.ws-premium-sub{font-size:12px;opacity:.85;line-height:1.4;margin-bottom:12px}
.ws-premium-price{font-size:28px;font-weight:1000;letter-spacing:-.02em;margin:4px 0 10px}
.ws-premium-price span{font-size:12px;opacity:.8;font-weight:700;margin-left:4px}
.ws-premium-pill{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800}

/* Sidebar nav */
.ws-nav{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.ws-nav-item{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:14px;border:1px solid transparent;background:transparent;cursor:pointer;font-weight:800;color:#374151;width:100%;text-align:left;transition:all .15s}
.ws-nav-item:hover{background:#fff;border-color:var(--border)}
.ws-nav-item.is-active{background:#fff;border-color:#ffd0dc;color:var(--primary);box-shadow:0 4px 12px rgba(255,46,99,.08)}
.ws-chip{margin-left:auto;background:#f3f4f6;border:1px solid var(--border);border-radius:999px;padding:3px 9px;font-size:11px;color:#6b7280;font-weight:900}

/* Feed */
.ws-view{min-height:0}
.ws-main-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.ws-main-head h2{margin:0;font-size:20px;font-weight:900}
.ws-select{background:#fff;border:1px solid var(--border);border-radius:12px;padding:8px 12px;font-weight:700;color:#111827;cursor:pointer}
.ws-main-head .ws-select{width:160px}

.ws-filterbar{display:flex;gap:8px;margin:10px 0 14px;flex-wrap:wrap}
.ws-pill{border:1px solid var(--border);background:#fff;border-radius:12px;padding:8px 14px;font-weight:900;color:#6b7280;cursor:pointer;font-size:13px;transition:all .15s}
.ws-pill.is-active{border-color:#ffd0dc;color:var(--primary);background:#fff5f7}
.ws-pill:hover:not(.is-active){background:#f3f4f6}

.ws-feed{display:flex;flex-direction:column;gap:14px}
.ws-post{padding:16px}
.ws-post-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.ws-avatar{width:38px;height:38px;border-radius:50%;background:#1e293b url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%2394a3b8"><path d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z"/></svg>') no-repeat center;background-size:65%;flex-shrink:0;border:1px solid #334155}
.ws-post-meta{flex:1;min-width:0}
.ws-post-title{display:flex;gap:8px;align-items:center;font-size:14px;flex-wrap:wrap}
.ws-muted{color:var(--muted)}
.ws-small{font-size:12px}
.ws-more{border:1px solid transparent;background:transparent;border-radius:10px;padding:6px 10px;cursor:pointer;color:#9ca3af;font-weight:900}
.ws-more:hover{background:#f3f4f6;color:#111827}

.ws-post-text{margin:0;font-size:14px;line-height:1.6;color:#374151}
.ws-post-text.is-clamped{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.ws-readmore{margin-top:6px;border:0;background:transparent;color:var(--primary);font-weight:900;cursor:pointer;font-size:13px}

/* Tag badge on post */
.ws-tag-badge{display:inline-flex;align-items:center;gap:4px;background:#fef2f2;border:1px solid #fecdd3;color:#be123c;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:800;margin-top:6px;cursor:pointer}
.ws-tag-badge:hover{background:#ffe4e6}

.ws-post-actions{display:flex;gap:14px;align-items:center;margin-top:12px;border-top:1px solid #f2f3f6;padding-top:10px}
.ws-action{border:0;background:transparent;cursor:pointer;color:#6b7280;font-weight:900;display:inline-flex;gap:6px;align-items:center;font-size:13px;transition:color .15s}
.ws-action:hover{color:var(--primary)}
.like-btn .heart{font-size:15px}

.comment-section{margin-top:10px}
.comment-list{list-style:none;padding:0;margin:0 0 10px;display:flex;flex-direction:column;gap:7px}
.comment{background:#f8fafc;border:1px solid #eef0f4;border-radius:12px;padding:9px 12px;color:#374151;font-size:13px}
.new-comment{border-color:#ffd0dc}

input[type="text"],input[type="password"],input[type="email"]{background:#fff;border:1px solid var(--border);border-radius:12px;padding:11px 12px;font-size:14px;width:100%}
input[type="text"]:focus,input[type="password"]:focus,input[type="email"]:focus{outline:none;border-color:var(--primary)}

/* Audio post */
.ws-audio-card{border:1px solid #ffd0dc;border-radius:16px;padding:14px;background:#fff5f7}
.ws-audio-card audio{width:100%}
.ws-badge{display:inline-flex;align-items:center;gap:6px;background:#ffe6ee;border:1px solid #ffd0dc;color:var(--primary);padding:3px 9px;border-radius:999px;font-size:11px;font-weight:1000}

.ws-locked{border:2px solid #ffd0dc;border-radius:16px;padding:18px;background:#fff5f7;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.ws-lock{width:44px;height:44px;border-radius:50%;background:#111827;color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px}
.ws-locked-title{font-weight:1000}

.ws-load{margin:4px auto 0;border:0;background:transparent;color:#9ca3af;font-weight:900;cursor:pointer;font-size:14px}
.ws-empty{padding:20px;text-align:center;color:var(--muted)}

/* Rightbar */
.ws-rightbar .ws-card{padding:16px}
.ws-trend-head{margin-bottom:12px;font-weight:900;font-size:15px}
.ws-trend-item{padding:9px 0;border-top:1px solid #f2f3f6;cursor:pointer;transition:background .15s}
.ws-trend-item:first-of-type{border-top:0}
.ws-trend-item:hover .ws-trend-tag{color:var(--primary)}
.ws-trend-tag{font-size:14px;font-weight:700;color:#111827}
.ws-trend-count{font-size:12px;color:var(--muted);margin-top:2px}
.ws-trend-list{max-height:320px;overflow-y:auto;padding-right:4px}
.ws-trend-list::-webkit-scrollbar{width:4px}
.ws-trend-list::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:4px}

/* ===== CHAT ===== */
.ws-chat-head{padding:14px 16px;border-bottom:1px solid #f2f3f6;display:flex;align-items:center;justify-content:space-between}
.ws-chat-partner{font-weight:900;font-size:15px}
.ws-wait{padding:14px 16px;color:var(--muted);font-weight:800;font-size:14px;display:flex;align-items:center;gap:10px}
.ws-countdown{font-size:13px;color:var(--primary);font-weight:900}

/* Chat box hidden until matched */
#chatBox{display:none}

.chat-messages{flex:1;min-height:0;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;height:420px;background:#f9fafb}
.msg{max-width:76%;padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.45;box-shadow:0 2px 8px rgba(17,24,39,.06);word-break:break-word}
.msg.sent{margin-left:auto;background:linear-gradient(135deg,var(--primary),#cc0033);color:#fff;border-bottom-right-radius:4px}
.msg.received{background:#fff;border:1px solid var(--border);color:#111827;border-bottom-left-radius:4px}
.msg img{max-width:240px;width:100%;border-radius:12px;display:block}
.msg audio{width:240px;max-width:100%}

.chat-footer{padding:12px 14px;border-top:1px solid #f2f3f6;background:#fff}
.input-row{display:flex;align-items:center;gap:8px}
.attach{cursor:pointer;background:#f3f4f6;border:1px solid #eef0f4;color:#111827;border-radius:12px;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;user-select:none;flex-shrink:0;font-size:16px}
#chatInput{flex:1;background:#f3f4f6;border:1px solid transparent;border-radius:12px;padding:10px 14px;font-size:14px;transition:all .15s}
#chatInput:focus{outline:none;border-color:var(--primary);background:#fff}
.send-btn{width:40px;height:40px;border-radius:12px;border:0;background:var(--primary);color:#fff;font-size:18px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .15s}
.send-btn:hover{background:#e6194d}

.action-row{display:flex;gap:10px;margin-top:10px}
.action-row button{flex:1}

/* Chat find panel */
.ws-find-panel{padding:30px 20px;display:flex;flex-direction:column;gap:18px;text-align:center;align-items:center}
.ws-intent-label{font-size:13px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.ws-premium-badge-inline{display:inline-flex;align-items:center;gap:4px;background:#ffe6ee;color:var(--primary);border:1px solid #ffd0dc;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:900;margin-left:6px;vertical-align:middle}

/* History view */
.history-item{padding:12px 16px;border-bottom:1px solid #f2f3f6;cursor:pointer;transition:background .15s;display:flex;align-items:center;gap:12px}
.history-item:hover{background:#f9fafb}
.history-item:last-child{border-bottom:0}
.history-avatar{width:36px;height:36px;border-radius:50%;background:#1e293b url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%2394a3b8"><path d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z"/></svg>') no-repeat center;background-size:65%;flex-shrink:0;border:1px solid #334155}
.history-msgs-panel{padding:16px;display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}

/* Modal */
.ws-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px}
.ws-modal-backdrop{position:absolute;inset:0;background:rgba(17,24,39,.6);backdrop-filter:blur(4px)}
.ws-modal-card{position:relative;width:min(520px,100%);background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:0 30px 80px rgba(0,0,0,.2);overflow:hidden;max-height:90vh;display:flex;flex-direction:column}
.ws-modal-head{padding:16px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f2f3f6;flex-shrink:0}
.ws-close{border:0;background:transparent;font-size:24px;cursor:pointer;color:#9ca3af;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px}
.ws-close:hover{background:#f3f4f6;color:#374151}
.ws-modal-tabs{display:flex;gap:8px;background:#f3f4f6;padding:8px;margin:14px 16px 0;border-radius:14px;flex-shrink:0}
.ws-tab{flex:1;border:1px solid transparent;background:transparent;border-radius:10px;padding:9px 12px;font-weight:900;cursor:pointer;color:#6b7280;font-size:13px;transition:all .15s}
.ws-tab.is-active{background:#fff;border-color:#eef0f4;color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.ws-modal-body{padding:14px 16px 16px;overflow-y:auto;flex:1}
#confessionText{width:100%;height:140px;resize:none;border:1px solid var(--border);border-radius:14px;padding:12px;font-size:14px;line-height:1.5}
#confessionText:focus{outline:none;border-color:var(--primary)}
.ws-modal-hint{display:flex;justify-content:space-between;margin-top:6px;font-size:12px;color:var(--muted)}
.ws-modal-foot{display:flex;align-items:center;gap:10px;margin-top:12px}
.ws-modal-foot .ws-btn{padding:9px 12px}

/* Tag input in modal */
.tag-input-wrap{position:relative;margin-top:10px}
.tag-input-field{width:100%;border:1px solid var(--border);border-radius:12px;padding:9px 12px;font-size:13px;background:#fafafa}
.tag-input-field:focus{outline:none;border-color:var(--primary);background:#fff}
.tag-suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:10;overflow:hidden;display:none}
.tag-suggestion-item{padding:9px 14px;font-size:13px;cursor:pointer;font-weight:700;color:#374151;transition:background .1s}
.tag-suggestion-item:hover{background:#f3f4f6;color:var(--primary)}

/* Audio recorder in modal */
.ws-recorder{border:2px dashed var(--border);border-radius:16px;padding:16px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;transition:border-color .3s}
.ws-recorder.recording{border-color:var(--primary);background:#fff5f7}
.ws-rec-indicator{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:800;color:var(--primary)}
.ws-rec-dot{width:10px;height:10px;border-radius:50%;background:var(--primary);animation:rec-blink 1s ease-in-out infinite}
@keyframes rec-blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.ws-rec-time{font-size:32px;font-weight:1000;color:#111827;letter-spacing:.02em;font-variant-numeric:tabular-nums}
.ws-rec-btn{width:66px;height:66px;border-radius:50%;border:0;background:var(--primary);color:#fff;font-size:20px;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(255,46,99,.3)}
.ws-rec-btn:hover{transform:scale(1.05);box-shadow:0 6px 20px rgba(255,46,99,.4)}
.ws-rec-btn.recording{background:#111827}
.ws-rec-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}

/* Scroll top */
.scroll-top{position:fixed;right:16px;bottom:80px;z-index:1500;background:var(--primary);color:#fff;border:0;border-radius:999px;padding:10px 14px;font-weight:1000;box-shadow:0 8px 24px rgba(255,46,99,.3);cursor:pointer;transition:opacity .2s}
@media(min-width:640px){.scroll-top{bottom:18px}}

/* ===== MOBILE BOTTOM TAB BAR ===== */
.mobile-tabbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:#fff;border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(17,24,39,.08)}
.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;border:0;background:transparent;cursor:pointer;color:#6b7280;font-size:10px;font-weight:800;transition:color .15s;position:relative;letter-spacing:.02em}
.mobile-tab.is-active{color:var(--primary)}
.mobile-tab.is-active::after{content:'';position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--primary);border-radius:0 0 4px 4px}
.mobile-tab-icon{font-size:20px;line-height:1}

/* Premium upsell toast */
.premium-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);z-index:1800;background:linear-gradient(135deg,#111827,#22102d);color:#fff;border:1px solid rgba(255,46,99,.3);border-radius:16px;padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:0 12px 40px rgba(0,0,0,.3);font-size:13px;font-weight:700;opacity:0;pointer-events:none;transition:all .4s ease;white-space:nowrap;max-width:90vw}
.premium-toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
@media(min-width:640px){.premium-toast{bottom:24px}}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .ws-layout{grid-template-columns:1fr;padding:12px;gap:12px}
  .ws-sidebar,.ws-rightbar{display:none}
  .mobile-tabbar{display:flex}
  .ws-topbar{padding:0 14px}
  .ws-brand-name{display:none}
  .ws-user-pill{display:none}
  .chat-messages{height:calc(100vh - 300px)}
}
@media(max-width:640px){
  .mobile-tab{flex-direction:row;padding:12px 8px;gap:6px;font-size:12px}
  .mobile-tab-icon{font-size:18px}
  .ws-find-panel{padding:20px 14px}
}
