/* ═══════════════════════════════════════════════════════
   TibetConnects Platform CSS
   Crimson · Saffron · Gold  |  All sections unified
═══════════════════════════════════════════════════════ */
:root {
    --tc-red:        #8B1A1A;
    --tc-red-dark:   #6B1212;
    --tc-red-soft:   #f5e8e8;
    --tc-saffron:    #E8930A;
    --tc-saffron-s:  #fef3e2;
    --tc-gold:       #C9972A;
    --tc-gold-s:     #fdf6e3;
    --tc-green:      #2a7a2a;
    --tc-green-s:    #e8f4e8;
    --tc-slate:      #1e2533;
    --tc-mid:        #4a5568;
    --tc-muted:      #718096;
    --tc-border:     #e8e0d5;
    --tc-bg:         #faf8f5;
    --tc-white:      #ffffff;
    --r:             10px;
    --r-sm:          6px;
    --shadow:        0 2px 12px rgba(0,0,0,.08);
    --shadow-h:      0 6px 24px rgba(0,0,0,.13);
    --font:          -apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
    --font-tib:      'Noto Serif Tibetan','Microsoft Himalaya',serif;
}

/* ── Base ───────────────────────────────────────────────── */
.tcp-section, .tcp-widget-grid, .tcp-submit-wrap, .tcp-profile,
.tcf-wrap {
    max-width: 1080px; margin: 0 auto; padding: 32px 20px 60px;
    font-family: var(--font); color: var(--tc-slate);
}
.tcp-section *, .tcp-widget-grid *, .tcf-wrap * { box-sizing: border-box; }
.tcp-section a, .tcf-wrap a { color: var(--tc-red); text-decoration: none; }
.tcp-section a:hover, .tcf-wrap a:hover { text-decoration: underline; }

/* ── Notices ────────────────────────────────────────────── */
.tcp-notice { padding:12px 18px; border-radius:var(--r-sm); margin-bottom:20px; font-size:14px; }
.tcp-notice-success { background:var(--tc-green-s); color:var(--tc-green); border:1px solid #b8d8b8; }
.tcp-notice-error   { background:#fde8e8; color:#c0392b; border:1px solid #e8b0b0; }

/* ── Section header ────────────────────────────────────── */
.tcp-section-head {
    display:flex; justify-content:space-between; align-items:center;
    margin-bottom:24px; padding-bottom:16px; border-bottom:2px solid var(--tc-border);
}
.tcp-section-title-wrap { display:flex; align-items:center; gap:14px; }
.tcp-section-icon  { font-size:28px; }
.tcp-section-title { font-size:22px; font-weight:700; margin:0; }
.tcp-section-tibetan { font-family:var(--font-tib); font-size:13px; color:var(--tc-muted); margin:0; }
.tcp-view-all {
    font-size:13px; font-weight:600; color:var(--tc-red);
    border:1.5px solid var(--tc-red); padding:7px 16px;
    border-radius:var(--r-sm); white-space:nowrap; text-decoration:none !important;
    transition:all .2s;
}
.tcp-view-all:hover { background:var(--tc-red); color:#fff !important; }

/* ── Search ─────────────────────────────────────────────── */
.tcp-search-form { display:flex; gap:8px; margin-bottom:16px; }
.tcp-search-input { flex:1; padding:10px 14px; border:1.5px solid var(--tc-border); border-radius:var(--r-sm); font-size:14px; font-family:var(--font); }
.tcp-search-input:focus { outline:none; border-color:var(--tc-red); }
.tcp-btn-search { background:var(--tc-red); color:#fff; border:none; padding:10px 20px; border-radius:var(--r-sm); font-weight:600; cursor:pointer; font-family:var(--font); }

/* ── Filter pills ───────────────────────────────────────── */
.tcp-filter-pills { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:16px; }
.tcp-pill {
    padding:4px 14px; border-radius:20px; border:1.5px solid var(--tc-border);
    font-size:13px; color:var(--tc-mid); background:var(--tc-white);
    text-decoration:none !important; transition:all .2s;
}
.tcp-pill:hover,.tcp-pill.tcp-active { background:var(--tc-red); border-color:var(--tc-red); color:#fff !important; }

/* ── Buttons ────────────────────────────────────────────── */
.tcp-btn { display:inline-flex; align-items:center; gap:6px; padding:9px 20px; border-radius:var(--r-sm); font-size:14px; font-weight:600; cursor:pointer; border:1.5px solid transparent; text-decoration:none !important; transition:all .2s; font-family:var(--font); }
.tcp-btn-primary { background:var(--tc-red); color:#fff !important; border-color:var(--tc-red); }
.tcp-btn-primary:hover { background:var(--tc-red-dark); }
.tcp-btn-sm { padding:6px 14px; font-size:13px; background:var(--tc-white); color:var(--tc-red) !important; border:1.5px solid var(--tc-red); margin-top:auto; align-self:flex-start; }
.tcp-btn-sm:hover { background:var(--tc-red); color:#fff !important; }
.tcp-btn-ghost { background:transparent; color:var(--tc-mid) !important; border-color:var(--tc-border); }
.tcp-btn-ghost:hover { border-color:var(--tc-red); color:var(--tc-red) !important; }
.tcp-post-btn { margin-bottom:16px; }

/* ── Cards grid ─────────────────────────────────────────── */
.tcp-card-grid { display:grid; gap:20px; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); }
.tcp-dir-grid  { grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); }
.tcp-card {
    background:var(--tc-white); border:1px solid var(--tc-border);
    border-radius:var(--r); overflow:hidden; display:flex; flex-direction:column;
    transition:box-shadow .2s,transform .2s;
}
.tcp-card:hover { box-shadow:var(--shadow-h); transform:translateY(-2px); }
.tcp-card-img img { width:100%; height:160px; object-fit:cover; display:block; }
.tcp-card-body { padding:18px; flex:1; display:flex; flex-direction:column; gap:6px; }
.tcp-card-title { font-size:15px; font-weight:700; margin:4px 0; line-height:1.3; }
.tcp-card-title a { color:var(--tc-slate); }
.tcp-card-title a:hover { color:var(--tc-red); text-decoration:none; }
.tcp-card-meta { font-size:13px; color:var(--tc-muted); margin:0; }
.tcp-tagline { font-size:13px; color:var(--tc-mid); font-style:italic; margin:0; }
.tcp-deadline { color:var(--tc-saffron); font-weight:600; }

/* ── Badges ─────────────────────────────────────────────── */
.tcp-badge {
    display:inline-block; padding:2px 10px; border-radius:20px;
    font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em;
    background:var(--tc-saffron-s); color:var(--tc-gold); border:1px solid #f0d9a0;
}
.tcp-badge-red     { background:#fde8e8; color:#c0392b; border-color:#e8b0b0; }
.tcp-badge-amber   { background:var(--tc-saffron-s); color:var(--tc-saffron); border-color:#f0d090; }
.tcp-badge-blue    { background:#e8edf5; color:#3a5a8a; border-color:#b8c8e0; }
.tcp-badge-gray    { background:#f0f0f0; color:#555; border-color:#ddd; }
.tcp-badge-type    { background:var(--tc-red-soft); color:var(--tc-red); border-color:#e8c0c0; }
.tcp-badge-mode    { background:var(--tc-green-s); color:var(--tc-green); border-color:#b8d8b8; }
.tcp-badge-lang    { background:#e8edf5; color:#3a5a8a; border-color:#b8c8e0; }
.tcp-badge-tibetan { background:var(--tc-gold-s); color:var(--tc-gold); border-color:#e0c878; }

/* ══════════════════════════════════════════════════════════
   EVENT PAGE — 3-column layout with filters + ads
══════════════════════════════════════════════════════════ */

/* Page wrapper */
.tce-page-wrap {
    background: var(--tc-bg);
    min-height: 60vh;
}

/* Page header */
.tce-page-header {
    background: linear-gradient(135deg, var(--tc-slate) 0%, #2d1010 100%);
    padding: 32px 0;
}
.tce-page-header-inner {
    max-width: 1200px; margin: 0 auto; padding: 0 24px;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    flex-wrap: wrap;
}
.tce-page-title {
    font-size: clamp(22px,3vw,30px); font-weight: 800; color: #fff;
    margin: 0 0 4px; line-height: 1.2;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
.tce-page-title-tib {
    font-size: 14px; font-weight: 400; opacity: .6;
    font-family: var(--font-tib); margin-left: 8px;
}
.tce-page-subtitle { font-size: 14px; color: rgba(255,255,255,.55); margin: 0; }
.tce-submit-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 11px 22px; border-radius: 9px;
    background: var(--tc-red); color: #fff !important;
    font-size: 14px; font-weight: 700;
    text-decoration: none !important; border: none;
    transition: background .18s; white-space: nowrap;
    flex-shrink: 0;
}
.tce-submit-btn:hover { background: var(--tc-red-dark); }

/* 3-column grid */
.tce-three-col {
    max-width: 1200px; margin: 0 auto;
    padding: 28px 24px 80px;
    display: grid;
    grid-template-columns: 220px 1fr 260px;
    gap: 24px;
    align-items: start;
}

/* ── LEFT: Filter sidebar ── */
.tce-filters-col { position: sticky; top: 80px; }

.tce-filter-toggle {
    display: none;
    align-items: center; gap: 8px;
    width: 100%; padding: 11px 16px;
    background: var(--tc-white); border: 1.5px solid var(--tc-border);
    border-radius: 10px; font-size: 14px; font-weight: 700;
    color: var(--tc-slate); cursor: pointer;
    font-family: var(--font); transition: all .15s;
    margin-bottom: 12px; position: relative;
}
.tce-filter-toggle:hover { border-color: var(--tc-red); }
.tce-filter-active-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--tc-red); position: absolute; right: 14px; top: 50%;
    transform: translateY(-50%);
}

.tce-filter-panel { display: flex; flex-direction: column; gap: 4px; }

.tce-filter-group {
    background: var(--tc-white);
    border: 1px solid var(--tc-border);
    border-radius: 10px; overflow: hidden;
    margin-bottom: 12px;
}
.tce-filter-title {
    font-size: 10px; font-weight: 800;
    text-transform: uppercase; letter-spacing: .09em;
    color: var(--tc-muted);
    padding: 12px 16px 8px; margin: 0;
    border-bottom: 1px solid var(--tc-border);
}
.tce-filter-list {
    list-style: none; padding: 6px 0; margin: 0;
}
.tce-filter-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 16px; font-size: 13px; font-weight: 500;
    color: var(--tc-mid); text-decoration: none !important;
    transition: background .14s, color .14s;
}
.tce-filter-item:hover { background: var(--tc-bg); color: var(--tc-slate); }
.tce-filter-item.tce-active {
    color: var(--tc-red); font-weight: 700;
    background: var(--tc-red-soft);
}
.tce-filter-count {
    font-size: 11px; font-weight: 700;
    background: var(--tc-bg); color: var(--tc-muted);
    border-radius: 20px; padding: 1px 7px;
    min-width: 22px; text-align: center;
}
.tce-filter-item.tce-active .tce-filter-count {
    background: var(--tc-red-soft); color: var(--tc-red);
}
.tce-clear-filters {
    display: block; text-align: center;
    font-size: 12px; font-weight: 700; color: var(--tc-muted) !important;
    text-decoration: none !important; padding: 10px;
    border: 1.5px dashed var(--tc-border); border-radius: 8px;
    transition: all .15s; margin-top: 4px;
}
.tce-clear-filters:hover { border-color: var(--tc-red); color: var(--tc-red) !important; }

/* ── CENTER: Event list ── */
.tce-events-col {}

.tce-results-bar {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 16px; padding-bottom: 12px;
    border-bottom: 1px solid var(--tc-border);
}
.tce-results-count { font-size: 14px; font-weight: 600; color: var(--tc-slate); }
.tce-results-filtered {
    font-size: 12px; font-weight: 700; color: var(--tc-red);
    background: var(--tc-red-soft); padding: 3px 10px;
    border-radius: 20px;
}

/* Event items */
.tce-list { display: flex; flex-direction: column; }
.tce-item {
    display: flex; align-items: stretch;
    background: var(--tc-white); border: 1px solid var(--tc-border);
    border-radius: 12px; overflow: hidden;
    margin-bottom: 12px;
    transition: box-shadow .2s, transform .2s;
}
.tce-item:hover { box-shadow: 0 6px 24px rgba(0,0,0,.10); transform: translateY(-2px); }

.tce-item-date {
    flex-shrink: 0; width: 76px;
    background: linear-gradient(175deg, var(--tc-red) 0%, var(--tc-red-dark) 100%);
    color: #fff; display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    padding: 16px 8px; text-align: center;
}
.tce-idate-dow { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.55); display: block; }
.tce-idate-day { font-size: 34px; font-weight: 800; line-height: 1; display: block; letter-spacing: -1px; margin-top: 2px; }
.tce-idate-mon { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: rgba(255,255,255,.75); display: block; margin-top: 4px; }
.tce-idate-yr  { font-size: 10px; color: rgba(255,255,255,.4); display: block; margin-top: 2px; }
.tce-idate-range { font-size: 9px; color: rgba(255,255,255,.5); display: block; margin-top: 6px; border-top: 1px solid rgba(255,255,255,.12); padding: 5px 4px 0; line-height: 1.4; }

.tce-item-body { flex: 1; min-width: 0; padding: 14px 16px 16px; display: flex; flex-direction: column; }
.tce-ibadges { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 7px; }
.tce-ibadge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 20px; font-size: 11px; font-weight: 700; background: var(--tc-bg); color: var(--tc-mid); border: 1px solid var(--tc-border); }
.tce-ibadge-mode { background: var(--tc-saffron-s); color: #92600A; border-color: #F0D090; }
.tce-ibadge-free { background: var(--tc-green-s); color: var(--tc-green); border-color: #b8d8b8; }

.tce-item-title { font-size: 15px; font-weight: 700; color: var(--tc-slate); margin: 0 0 6px; line-height: 1.3; }
.tce-item-title a { color: var(--tc-slate); text-decoration: none; transition: color .15s; }
.tce-item-title a:hover { color: var(--tc-red); }
.tce-item-meta { display: flex; flex-wrap: wrap; gap: 10px; font-size: 12px; color: var(--tc-muted); margin-bottom: 7px; }
.tce-item-meta span { display: flex; align-items: center; gap: 4px; }
.tce-item-excerpt { font-size: 12px; color: var(--tc-muted); line-height: 1.5; margin: 0 0 10px; }
.tce-item-actions { display: flex; flex-wrap: wrap; gap: 7px; margin-top: auto; padding-top: 10px; border-top: 1px solid var(--tc-border); }
.tce-item-link { font-size: 12px; font-weight: 700; color: var(--tc-red) !important; text-decoration: none !important; padding: 5px 0; }
.tce-item-link:hover { text-decoration: underline !important; }
.tce-item-rsvp { display: inline-flex; align-items: center; gap: 4px; padding: 5px 12px; border-radius: 7px; background: var(--tc-green-s); color: var(--tc-green) !important; border: 1.5px solid #b8d8b8; font-size: 12px; font-weight: 700; text-decoration: none !important; transition: all .15s; }
.tce-item-rsvp:hover { background: var(--tc-green); color: #fff !important; border-color: var(--tc-green); }
.tce-item-discuss { display: inline-flex; align-items: center; gap: 4px; padding: 5px 12px; border-radius: 7px; background: var(--tc-bg); color: var(--tc-mid) !important; border: 1.5px solid var(--tc-border); font-size: 12px; font-weight: 700; text-decoration: none !important; transition: all .15s; }
.tce-item-discuss:hover { border-color: var(--tc-red); color: var(--tc-red) !important; }

.tce-item-thumb { flex-shrink: 0; width: 120px; overflow: hidden; }
.tce-item-thumb img { width: 100%; height: 100%; min-height: 120px; object-fit: cover; display: block; transition: transform .35s; }
.tce-item:hover .tce-item-thumb img { transform: scale(1.05); }

/* No events */
.tce-no-events { text-align: center; padding: 60px 20px; background: var(--tc-white); border: 1px solid var(--tc-border); border-radius: 12px; }
.tce-no-events-icon { font-size: 44px; margin-bottom: 14px; filter: grayscale(1) opacity(.4); }
.tce-no-events h3 { font-size: 18px; font-weight: 700; color: var(--tc-slate); margin: 0 0 8px; }
.tce-no-events p { font-size: 14px; color: var(--tc-muted); margin: 0 0 16px; }
.tce-clear-btn { display: inline-block; padding: 9px 20px; background: var(--tc-red); color: #fff !important; border-radius: 8px; font-size: 13px; font-weight: 700; text-decoration: none !important; }

/* ── RIGHT: Ad sidebar ── */
.tce-ads-col { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 80px; }
.tce-ad-card { background: var(--tc-white); border: 1px solid var(--tc-border); border-radius: 10px; overflow: hidden; }
.tce-ad-label { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--tc-muted); padding: 8px 12px 6px; border-bottom: 1px solid var(--tc-border); }
.tce-ad-placeholder { padding: 0; }
.tce-ad-ph-inner { height: 250px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; background: var(--tc-bg); }
.tce-ad-ph-inner span { font-size: 13px; font-weight: 600; color: #bbb; }
.tce-ad-ph-inner small { font-size: 11px; color: #ccc; }

/* CTA card */
.tce-cta-card { padding: 20px; text-align: center; border-left: 3px solid var(--tc-red); }
.tce-cta-card-icon { font-size: 28px; margin-bottom: 10px; }
.tce-cta-card-title { font-size: 14px; font-weight: 800; color: var(--tc-slate); margin: 0 0 8px; }
.tce-cta-card-text { font-size: 12px; color: var(--tc-muted); margin: 0 0 14px; line-height: 1.5; }
.tce-cta-card-btn { display: inline-block; padding: 9px 18px; background: var(--tc-red); color: #fff !important; border-radius: 8px; font-size: 13px; font-weight: 700; text-decoration: none !important; transition: background .18s; }
.tce-cta-card-btn:hover { background: var(--tc-red-dark); }

/* ── Responsive ── */
@media (max-width: 1024px) {
    .tce-three-col { grid-template-columns: 200px 1fr 220px; gap: 18px; }
}
@media (max-width: 860px) {
    .tce-three-col { grid-template-columns: 1fr; padding: 16px 16px 60px; }
    .tce-filters-col { position: static; }
    .tce-ads-col { position: static; flex-direction: row; flex-wrap: wrap; }
    .tce-ad-card { flex: 1 1 200px; }
    .tce-filter-toggle { display: flex; }
    .tce-filter-panel { display: none; }
    .tce-filter-panel.tce-open { display: flex; }
    .tce-page-header { padding: 24px 0; }
    .tce-page-header-inner { padding: 0 16px; }
}
@media (max-width: 540px) {
    .tce-item { flex-wrap: wrap; }
    .tce-item-date { width: 100%; flex-direction: row; padding: 10px 14px; gap: 8px; justify-content: flex-start; border-radius: 12px 12px 0 0; }
    .tce-idate-day { font-size: 22px; letter-spacing: 0; }
    .tce-idate-range { border-top: none; padding-top: 0; margin-top: 0; }
    .tce-item-thumb { width: 100%; height: 150px; }
    .tce-item-thumb img { min-height: 150px; }
    .tce-ads-col { display: none; }
}
/* ── Directory cards ─────────────────────────────────────── */
.tcp-dir-grid { grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); }
.tcp-dir-card { flex-direction:column; text-align:center; }
.tcp-dir-avatar-wrap { padding:24px 24px 0; display:flex; justify-content:center; }
.tcp-dir-avatar { width:80px; height:80px; border-radius:50%; overflow:hidden; border:3px solid var(--tc-red-soft); flex-shrink:0; }
.tcp-dir-avatar img { width:100%; height:100%; object-fit:cover; }
.tcp-dir-initial { background:var(--tc-red-soft); display:flex; align-items:center; justify-content:center; }
.tcp-dir-initial span { font-size:32px; font-weight:700; color:var(--tc-red); }
.tcp-dir-body { padding:14px 18px 18px; flex:1; display:flex; flex-direction:column; gap:4px; align-items:center; }
.tcp-dir-body .tcp-card-title { font-size:15px; margin:6px 0 2px; }
.tcp-dir-body .tcp-tagline { color:var(--tc-muted); font-size:12px; font-weight:500; font-style:normal; }
.tcp-dir-actions { display:flex; gap:6px; flex-wrap:wrap; justify-content:center; margin-top:10px; padding-top:10px; border-top:1px solid var(--tc-border); width:100%; }
.tcp-dir-link { font-size:12px; font-weight:600; color:var(--tc-mid); text-decoration:none !important; padding:5px 10px; border:1.5px solid var(--tc-border); border-radius:5px; transition:all .15s; }
.tcp-dir-link:hover { border-color:var(--tc-red); color:var(--tc-red); }

/* ── Business cards (Yelp-inspired archive) ─────────────── */
.tcp-biz-grid {
    grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
    gap:20px;
}

/* Card shell */
.tcp-biz-card {
    background:var(--tc-white);
    border:1px solid var(--tc-border);
    border-radius:12px;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    box-shadow:0 2px 8px rgba(0,0,0,.05);
    transition:box-shadow .2s,transform .2s;
    position:relative;
}
.tcp-biz-card:hover {
    box-shadow:0 10px 32px rgba(0,0,0,.12);
    transform:translateY(-3px);
}

/* Tibetan-owned accent */
.tcp-biz-card:has(.tcp-badge-tibetan) {
    border-color:rgba(201,151,42,.25);
}
.tcp-biz-card:has(.tcp-badge-tibetan)::before {
    content:'';
    position:absolute;
    top:0; left:0; right:0;
    height:3px;
    background:linear-gradient(90deg, var(--tc-saffron), var(--tc-gold, #c9972a));
}

/* Image area */
.tcp-biz-card .tcp-card-img img {
    width:100%; height:190px;
    object-fit:cover; display:block;
    transition:transform .35s ease;
}
.tcp-biz-card:hover .tcp-card-img img { transform:scale(1.04); }
.tcp-biz-card .tcp-card-img { overflow:hidden; }

/* Dark elegant placeholder */
.tcp-biz-placeholder {
    height:190px;
    background:linear-gradient(135deg, #1a0505 0%, #2d1010 55%, #0d1829 100%);
    display:flex; align-items:center; justify-content:center;
    position:relative; overflow:hidden;
}
.tcp-biz-placeholder::before {
    content:''; position:absolute; inset:0;
    background:radial-gradient(circle at 30% 50%, rgba(201,151,42,.1), transparent 65%);
}
.tcp-biz-placeholder span {
    font-size:64px; font-weight:800;
    color:rgba(255,255,255,.1); position:relative;
    z-index:1; letter-spacing:-3px; line-height:1;
    font-family:Georgia,serif;
}

/* Card body */
.tcp-biz-card .tcp-card-body {
    padding:16px 18px 18px;
    flex:1; display:flex; flex-direction:column; gap:0;
}

/* Badges row */
.tcp-biz-badges { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:8px; }
.tcp-badge-tibetan {
    background:rgba(201,151,42,.1);
    color:#8a6000;
    border-color:rgba(201,151,42,.25);
}

/* Title & tagline */
.tcp-biz-card .tcp-card-title { font-size:16px; font-weight:700; margin:0 0 4px; line-height:1.3; }
.tcp-biz-card .tcp-card-title a { color:var(--tc-slate); text-decoration:none !important; }
.tcp-biz-card .tcp-card-title a:hover { color:var(--tc-red); }
.tcp-biz-card .tcp-tagline { font-size:13px; color:var(--tc-muted); margin:0 0 10px; line-height:1.4; }

/* Rating row on card */
.tcb-card-rating {
    display:flex; align-items:center; gap:6px;
    margin-bottom:8px; font-size:13px;
}
.tcb-card-stars { color:#e8a800; letter-spacing:1px; }
.tcb-card-avg   { font-weight:700; color:var(--tc-slate); font-size:13px; }
.tcb-card-rcount { color:var(--tc-muted); font-size:12px; }

/* Distance pill */
.tcb-dist {
    display:inline-flex; align-items:center; gap:4px;
    font-size:12px; color:var(--tc-green); font-weight:700;
    background:var(--tc-green-s); border-radius:20px;
    padding:2px 10px; margin-bottom:8px; align-self:flex-start;
}
.tcb-city {
    display:block; font-size:12px;
    color:var(--tc-muted); margin-bottom:8px;
}

/* Hours */
.tcp-biz-card .tcp-card-meta { font-size:12px; color:var(--tc-muted); margin:0 0 10px; }

/* Contact chips — push to bottom */
.tcp-biz-contacts {
    display:flex; flex-wrap:wrap; gap:6px;
    margin-top:auto; padding-top:12px;
    border-top:1px solid var(--tc-border);
}
.tcp-biz-contact {
    display:inline-flex; align-items:center; gap:5px;
    font-size:12px; font-weight:600; color:var(--tc-mid);
    text-decoration:none !important;
    padding:5px 12px; border:1.5px solid var(--tc-border);
    border-radius:20px; background:var(--tc-bg);
    transition:all .15s;
}
.tcp-biz-contact:hover {
    border-color:var(--tc-red); color:var(--tc-red);
    background:var(--tc-red-soft);
}
.tcp-card-actions {
    display:flex; gap:8px; margin-top:10px;
    flex-wrap:wrap; align-items:center;
}

/* ── Location & filter bar (Yelp-style dark) ───────────── */
.tcb-loc-bar {
    background:linear-gradient(135deg, var(--tc-slate) 0%, #2d0d0d 100%);
    border-radius:12px; padding:18px 22px; margin-bottom:22px;
    display:flex; align-items:center; gap:18px; flex-wrap:wrap;
    box-shadow:0 6px 24px rgba(0,0,0,.18);
}
.tcb-loc-inner { display:flex; align-items:center; gap:10px; }
.tcb-loc-btn {
    display:inline-flex; align-items:center; gap:8px;
    padding:10px 18px; background:rgba(255,255,255,.12);
    color:#fff; border:1.5px solid rgba(255,255,255,.2);
    border-radius:8px; font-size:13px; font-weight:700;
    cursor:pointer; font-family:inherit; transition:all .18s; white-space:nowrap;
}
.tcb-loc-btn:hover { background:var(--tc-red); border-color:var(--tc-red); }
.tcb-loc-btn:disabled { opacity:.5; cursor:wait; }
.tcb-loc-status { font-size:12px; color:#7ed87e; font-weight:600; }
.tcb-loc-clear {
    background:none; border:1px solid rgba(255,255,255,.2);
    border-radius:20px; padding:4px 13px;
    font-size:12px; color:rgba(255,255,255,.55);
    cursor:pointer; transition:all .15s;
}
.tcb-loc-clear:hover { border-color:rgba(255,255,255,.45); color:#fff; }
.tcb-loc-filters { display:flex; gap:10px; flex:1; flex-wrap:wrap; }
.tcb-loc-filters select,
.tcb-loc-filters input {
    padding:10px 14px; border:1.5px solid rgba(255,255,255,.15);
    border-radius:8px; font-size:13px; font-family:inherit;
    color:#fff; background:rgba(255,255,255,.1); transition:all .18s;
}
.tcb-loc-filters input { flex:1; min-width:180px; }
.tcb-loc-filters select option { color:var(--tc-slate); background:#fff; }
.tcb-loc-filters input::placeholder { color:rgba(255,255,255,.4); }
.tcb-loc-filters select:focus,
.tcb-loc-filters input:focus {
    outline:none; border-color:rgba(255,255,255,.45);
    background:rgba(255,255,255,.16);
}
.tcb-results-meta {
    font-size:13px; color:var(--tc-muted);
    margin-bottom:18px; font-weight:500;
}

/* ── News list ──────────────────────────────────────────── */
.tcp-news-list { display:flex; flex-direction:column; gap:16px; }
.tcp-news-card { display:flex; gap:16px; background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); overflow:hidden; border-left:4px solid var(--tc-red); transition:box-shadow .2s; }
.tcp-news-card:hover { box-shadow:var(--shadow); }
.tcp-news-img img { width:120px; height:90px; object-fit:cover; flex-shrink:0; }
.tcp-news-body { flex:1; padding:16px; }
.tcp-news-meta { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:6px; }
.tcp-news-meta time { font-size:12px; color:var(--tc-muted); }
.tcp-source { font-size:12px; color:var(--tc-muted); font-style:italic; }
.tcp-news-body h3 { margin:0 0 6px; font-size:16px; line-height:1.3; }
.tcp-news-body h3 a { color:var(--tc-slate); }
.tcp-news-body h3 a:hover { color:var(--tc-red); text-decoration:none; }
.tcp-excerpt { font-size:14px; color:var(--tc-mid); margin:0 0 8px; line-height:1.5; }
.tcp-read-more { font-size:13px; font-weight:600; color:var(--tc-red); }

/* ── Resource list ──────────────────────────────────────── */
.tcp-resource-list { display:flex; flex-direction:column; gap:8px; }
.tcp-resource-row { display:flex; gap:14px; align-items:flex-start; padding:16px; background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); transition:box-shadow .2s; }
.tcp-resource-row:hover { box-shadow:var(--shadow); }
.tcp-res-icon { font-size:22px; flex-shrink:0; margin-top:2px; }
.tcp-res-body { flex:1; }
.tcp-res-body h4 { margin:0 0 4px; font-size:15px; font-weight:600; }
.tcp-res-body h4 a { color:var(--tc-slate); }
.tcp-res-body h4 a:hover { color:var(--tc-red); text-decoration:none; }
.tcp-res-desc { font-size:13px; color:var(--tc-mid); margin:0 0 8px; }
.tcp-res-tags { display:flex; gap:6px; flex-wrap:wrap; align-items:center; font-size:12px; color:var(--tc-muted); }

/* ── Empty state ────────────────────────────────────────── */
.tcp-empty { text-align:center; padding:48px 24px; background:var(--tc-white); border:1px dashed var(--tc-border); border-radius:var(--r); }
.tcp-empty p { color:var(--tc-muted); font-size:15px; margin:0; }

/* ── Pagination ─────────────────────────────────────────── */
.tcp-pagination { margin:24px 0; }
.tcp-pagination .page-numbers { list-style:none; display:flex; gap:4px; padding:0; flex-wrap:wrap; }
.tcp-pagination .page-numbers li a,
.tcp-pagination .page-numbers li span { display:flex; align-items:center; justify-content:center; width:36px; height:36px; border:1.5px solid var(--tc-border); border-radius:var(--r-sm); font-size:14px; color:var(--tc-mid); text-decoration:none; transition:all .2s; }
.tcp-pagination .page-numbers li .current,
.tcp-pagination .page-numbers li a:hover { background:var(--tc-red); border-color:var(--tc-red); color:#fff; }

/* ══════════════════════════════════════════════════════════
   HOMEPAGE WIDGET GRID
══════════════════════════════════════════════════════════ */
.tcp-widget-grid { display:grid; gap:20px; grid-template-columns:repeat(3,1fr); padding:0; }
.tcp-widget-card { background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); display:flex; flex-direction:column; overflow:hidden; transition:box-shadow .2s,transform .2s; }
.tcp-widget-card:hover { box-shadow:var(--shadow-h); transform:translateY(-2px); }
.tcp-widget-head { display:flex; align-items:center; gap:12px; padding:16px; border-bottom:3px solid var(--tc-red); }
.tcp-widget-icon { font-size:24px; }
.tcp-widget-title { font-size:15px; font-weight:700; margin:0; color:var(--tc-slate); }
.tcp-widget-tib { font-family:var(--font-tib); font-size:12px; color:var(--tc-muted); margin:0; }
.tcp-widget-body { flex:1; padding:12px 16px; display:flex; flex-direction:column; gap:6px; }
.tcp-widget-item { font-size:13px; color:var(--tc-mid); line-height:1.4; padding:6px 0; border-bottom:1px solid var(--tc-border); display:block; text-decoration:none !important; }
.tcp-widget-item:last-child { border-bottom:none; }
.tcp-widget-item:hover { color:var(--tc-red); }
.tcp-widget-empty { font-size:13px; color:var(--tc-muted); font-style:italic; margin:8px 0; }
.tcp-widget-footer { display:block; padding:12px 16px; border-top:1px solid var(--tc-border); font-size:13px; font-weight:600; color:var(--tc-red); text-decoration:none !important; text-align:center; background:var(--tc-bg); transition:background .2s; }
.tcp-widget-footer:hover { background:var(--tc-red-soft); }

/* ══════════════════════════════════════════════════════════
   SUBMISSION FORM
══════════════════════════════════════════════════════════ */
.tcp-submit-tabs { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:24px; }
.tcp-submit-tab { padding:8px 16px; border-radius:var(--r-sm); border:1.5px solid var(--tc-border); font-size:13px; font-weight:600; color:var(--tc-mid); text-decoration:none !important; transition:all .2s; }
.tcp-submit-tab:hover { border-color:var(--tc-red); color:var(--tc-red); }
.tcp-submit-tab.tcp-tab-active { background:var(--tc-red); border-color:var(--tc-red); color:#fff !important; }
.tcp-submit-form { max-width:700px; }
.tcp-form-group { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.tcp-form-group label,.tcp-form label { font-size:14px; font-weight:600; color:var(--tc-slate); }
.req { color:var(--tc-red); }
.tcp-input,.tcp-select,.tcp-textarea {
    padding:10px 14px; border:1.5px solid var(--tc-border);
    border-radius:var(--r-sm); font-size:14px; font-family:var(--font);
    background:var(--tc-white); color:var(--tc-slate); width:100%; transition:border-color .2s;
}
.tcp-input:focus,.tcp-select:focus,.tcp-textarea:focus { outline:none; border-color:var(--tc-red); }
.tcp-textarea { resize:vertical; }
.tcp-form-footer { display:flex; align-items:center; gap:16px; padding-top:8px; }
.tcp-form-note { font-size:12px; color:var(--tc-muted); margin:0; }

/* ── Profile ────────────────────────────────────────────── */
.tcp-profile { max-width:700px; }
.tcp-profile-header { display:flex; gap:20px; align-items:flex-start; background:var(--tc-white); border:1px solid var(--tc-border); border-top:3px solid var(--tc-red); border-radius:var(--r); padding:24px; margin-bottom:24px; }
.tcp-profile-avatar { border-radius:50%; border:3px solid var(--tc-red-soft); flex-shrink:0; }
.tcp-profile-header h2 { font-size:20px; margin:0 0 4px; }
.tcp-profile-role { color:var(--tc-red); font-size:13px; font-weight:600; margin:0 0 12px; }
.tcp-profile-stats { display:flex; gap:20px; font-size:14px; color:var(--tc-mid); flex-wrap:wrap; }
.tcp-profile-stats strong { display:block; font-size:20px; color:var(--tc-slate); }

/* ══════════════════════════════════════════════════════════
   FORUM STYLES (adapted from tc-forum)
══════════════════════════════════════════════════════════ */
.tcf-wrap { padding:32px 20px 60px; }
.tcf-notice,.tcp-notice { padding:12px 18px; border-radius:var(--r-sm); margin-bottom:20px; font-size:14px; }
.tcf-notice-success,.tcp-notice-success { background:var(--tc-green-s); color:var(--tc-green); border:1px solid #b8d8b8; }
.tcf-notice-error,.tcp-notice-error     { background:#fde8e8; color:#c0392b; border:1px solid #e8b0b0; }

.tcf-forum-hero { background:var(--tc-red); color:#fff; border-radius:var(--r); padding:32px 36px; margin-bottom:28px; }
.tcf-forum-hero h1 { font-size:24px; margin:0 0 4px; font-weight:700; }
.tcf-tibetan { font-family:var(--font-tib); font-size:15px; opacity:.8; margin:0 0 18px; }
.tcf-hero-cta { display:flex; gap:10px; }
.tcf-forum-hero .tcf-btn-new { background:var(--tc-saffron); border-color:var(--tc-saffron); color:#fff !important; }
.tcf-forum-hero .tcf-btn-ghost { border-color:rgba(255,255,255,.4); color:#fff !important; }

.tcf-stats-bar { display:flex; align-items:center; gap:24px; flex-wrap:wrap; padding:14px 20px; background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); margin-bottom:28px; font-size:14px; }
.tcf-stat { color:var(--tc-mid); }
.tcf-stat strong { color:var(--tc-slate); font-weight:700; margin-right:4px; }
.tcf-stats-bar .tcf-btn,.tcf-stats-bar .tcp-btn { margin-left:auto; }

.tcf-group { margin-bottom:28px; }
.tcf-group-title { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--tc-muted); display:flex; align-items:center; gap:8px; padding-bottom:8px; border-bottom:1px solid var(--tc-border); margin-bottom:0; }

.tcf-category-list { border:1px solid var(--tc-border); border-top:none; border-radius:0 0 var(--r) var(--r); background:var(--tc-white); overflow:hidden; }
.tcf-category-row { display:grid; grid-template-columns:52px 1fr 140px 200px; align-items:center; gap:16px; padding:18px 20px; border-bottom:1px solid var(--tc-border); transition:background .15s; }
.tcf-category-row:last-child { border-bottom:none; }
.tcf-category-row:hover { background:var(--tc-bg); }
.tcf-cat-icon-wrap { width:44px; height:44px; background:var(--tc-red-soft); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.tcf-cat-name { font-size:15px; font-weight:700; color:var(--tc-slate); display:block; margin-bottom:3px; }
.tcf-cat-name:hover { color:var(--tc-red); text-decoration:none; }
.tcf-cat-desc { font-size:13px; color:var(--tc-muted); margin:0; }
.tcf-cat-counts { display:flex; flex-direction:column; gap:3px; font-size:13px; color:var(--tc-mid); }
.tcf-cat-counts em { font-style:normal; color:var(--tc-muted); font-size:11px; }
.tcf-cat-last { font-size:12px; }
.tcf-last-title { display:block; color:var(--tc-mid); margin-bottom:2px; line-height:1.3; }
.tcf-last-title:hover { color:var(--tc-red); text-decoration:none; }
.tcf-last-time,.tcf-no-posts { color:var(--tc-muted); font-style:italic; }

.tcf-recent-panel { background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); padding:20px; margin-top:28px; }
.tcf-panel-title { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--tc-muted); margin:0 0 16px; }
.tcf-recent-item { display:flex; gap:10px; align-items:flex-start; padding:10px 0; border-bottom:1px solid var(--tc-border); }
.tcf-recent-item:last-child { border-bottom:none; }
.tcf-recent-link { font-size:14px; color:var(--tc-slate); display:block; line-height:1.3; }
.tcf-recent-link:hover { color:var(--tc-red); text-decoration:none; }
.tcf-recent-meta { font-size:12px; color:var(--tc-muted); display:block; margin-top:2px; }

.tcf-cat-header { display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-bottom:20px; flex-wrap:wrap; }
.tcf-cat-title { font-size:22px; font-weight:700; margin:0 0 4px; }
.tcf-cat-subtitle { font-size:14px; color:var(--tc-muted); margin:0; }
.tcf-page-title { font-size:22px; font-weight:700; margin:0 0 24px; }

.tcf-filter-tabs { display:flex; gap:4px; margin-bottom:20px; border-bottom:2px solid var(--tc-border); }
.tcf-tab { padding:8px 16px; font-size:14px; font-weight:500; color:var(--tc-muted); border-bottom:2px solid transparent; margin-bottom:-2px; transition:all .2s; text-decoration:none !important; }
.tcf-tab:hover { color:var(--tc-slate); }
.tcf-tab-active { color:var(--tc-red) !important; border-bottom-color:var(--tc-red); font-weight:600; }

.tcf-topic-list { border:1px solid var(--tc-border); border-radius:var(--r); background:var(--tc-white); overflow:hidden; }
.tcf-topic-list-header { display:grid; grid-template-columns:1fr 80px 80px 120px; gap:16px; padding:10px 20px; background:var(--tc-bg); border-bottom:1px solid var(--tc-border); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--tc-muted); }
.tcf-topic-row { display:grid; grid-template-columns:1fr 80px 80px 120px; gap:16px; padding:14px 20px; align-items:center; border-bottom:1px solid var(--tc-border); transition:background .15s; }
.tcf-topic-row:last-child { border-bottom:none; }
.tcf-topic-row:hover { background:var(--tc-bg); }
.tcf-sticky { background:#fffde8 !important; }
.tcf-topic-main { display:flex; align-items:center; gap:12px; min-width:0; }
.tcf-topic-info { min-width:0; }
.tcf-topic-title { font-size:14px; font-weight:600; color:var(--tc-slate); display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.tcf-topic-title:hover { color:var(--tc-red); text-decoration:none; }
.tcf-topic-meta { font-size:12px; color:var(--tc-muted); display:block; margin-top:2px; }
.tcf-topic-replies,.tcf-topic-views { font-size:14px; color:var(--tc-mid); text-align:center; }
.tcf-topic-last { font-size:12px; color:var(--tc-muted); }
.tcf-solved-badge { background:var(--tc-green-s); color:var(--tc-green); font-size:11px; font-weight:700; padding:2px 8px; border-radius:20px; flex-shrink:0; }

.tcf-empty,.tcp-empty { text-align:center; padding:48px 24px; background:var(--tc-white); border:1px dashed var(--tc-border); border-radius:var(--r); }
.tcf-empty p,.tcp-empty p { color:var(--tc-muted); margin-bottom:16px; }
.tcf-empty-small { color:var(--tc-muted); font-size:13px; font-style:italic; }

.tcf-post { display:flex; background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); margin-bottom:12px; overflow:hidden; }
.tcf-post-sidebar { width:120px; flex-shrink:0; background:var(--tc-bg); border-right:1px solid var(--tc-border); padding:20px 12px; display:flex; flex-direction:column; align-items:center; gap:6px; text-align:center; }
.tcf-post-author { font-size:13px; font-weight:700; color:var(--tc-slate); word-break:break-word; }
.tcf-post-role { font-size:11px; background:var(--tc-red-soft); color:var(--tc-red); padding:2px 8px; border-radius:20px; }
.tcf-post-count { font-size:11px; color:var(--tc-muted); }
.tcf-post-body { flex:1; padding:20px 24px; min-width:0; display:flex; flex-direction:column; gap:12px; }
.tcf-post-head { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.tcf-post-time { font-size:12px; color:var(--tc-muted); margin-left:auto; }
.tcf-topic-post { border-top:3px solid var(--tc-red); }
.tcf-solution-post { border-left:4px solid var(--tc-green); }
.tcf-solution-label { background:var(--tc-green-s); color:var(--tc-green); font-size:12px; font-weight:700; padding:3px 10px; border-radius:20px; }

.tcf-post-content { font-size:15px; line-height:1.75; color:var(--tc-slate); }
.tcf-post-content p { margin:0 0 12px; }
.tcf-post-content p:last-child { margin-bottom:0; }
.tcf-post-content blockquote { border-left:3px solid var(--tc-saffron); padding:10px 16px; background:var(--tc-gold-s); border-radius:0 var(--r-sm) var(--r-sm) 0; margin:12px 0; font-style:italic; color:var(--tc-mid); }
.tcf-post-content code { background:#f0f0f0; padding:2px 6px; border-radius:3px; font-size:13px; font-family:monospace; }
.tcf-post-content pre { background:#1e2533; color:#e2e8f0; padding:16px; border-radius:var(--r-sm); overflow-x:auto; font-size:13px; font-family:monospace; margin:12px 0; }

.tcf-post-actions { display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding-top:12px; border-top:1px solid var(--tc-border); margin-top:auto; }
.tcf-action-link { font-size:13px; color:var(--tc-muted); cursor:pointer; }
.tcf-action-link:hover { color:var(--tc-red); text-decoration:none; }
.tcf-like-btn { display:inline-flex; align-items:center; gap:5px; background:none; border:1px solid var(--tc-border); padding:4px 12px; border-radius:20px; font-size:13px; cursor:pointer; color:var(--tc-mid); transition:all .2s; font-family:var(--font); }
.tcf-like-btn:hover { border-color:var(--tc-red); color:var(--tc-red); }
.tcf-like-btn.tcf-liked { background:var(--tc-red-soft); border-color:var(--tc-red); color:var(--tc-red); }
.tcf-subscribe-btn { background:none; border:1px solid var(--tc-border); padding:4px 12px; border-radius:20px; font-size:13px; cursor:pointer; color:var(--tc-mid); transition:all .2s; font-family:var(--font); }
.tcf-subscribe-btn:hover,.tcf-subscribe-btn.tcf-subscribed { border-color:var(--tc-saffron); color:var(--tc-saffron); }

.tcf-replies-heading { font-size:16px; font-weight:700; margin:28px 0 12px; padding-bottom:8px; border-bottom:2px solid var(--tc-border); }
.tcf-reply-form-wrap { background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); padding:24px; margin-top:24px; }
.tcf-reply-form-wrap h3 { font-size:16px; font-weight:700; margin:0 0 16px; }
.tcf-login-prompt { text-align:center; padding:32px; background:var(--tc-white); border:1px dashed var(--tc-border); border-radius:var(--r); margin-top:24px; display:flex; gap:12px; justify-content:center; align-items:center; flex-wrap:wrap; }
.tcf-closed-notice { background:#f0f0f0; color:var(--tc-muted); text-align:center; padding:16px; border-radius:var(--r); margin-top:20px; font-size:14px; }

.tcf-form { display:flex; flex-direction:column; gap:16px; }
.tcf-form-row { display:flex; flex-direction:column; gap:5px; }
.tcf-form-row label { font-size:14px; font-weight:600; color:var(--tc-slate); }
.tcf-input,.tcf-select,.tcf-editor { padding:10px 14px; border:1.5px solid var(--tc-border); border-radius:var(--r-sm); font-size:14px; font-family:var(--font); background:var(--tc-white); color:var(--tc-slate); width:100%; transition:border-color .2s; }
.tcf-input:focus,.tcf-select:focus,.tcf-editor:focus { outline:none; border-color:var(--tc-red); }
.tcf-editor { resize:vertical; line-height:1.6; }
.tcf-form-footer { display:flex; gap:12px; align-items:center; }
.tcf-editor-toolbar { display:flex; gap:4px; margin-top:6px; }
.tcf-fmt-btn { background:var(--tc-bg); border:1px solid var(--tc-border); border-radius:4px; padding:4px 10px; cursor:pointer; font-size:13px; color:var(--tc-mid); font-family:var(--font); transition:all .15s; }
.tcf-fmt-btn:hover { border-color:var(--tc-red); color:var(--tc-red); }

.tcf-modal { position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:9999; display:flex; align-items:center; justify-content:center; }
.tcf-modal-inner { background:var(--tc-white); border-radius:var(--r); padding:28px; width:100%; max-width:600px; box-shadow:0 20px 60px rgba(0,0,0,.25); max-height:90vh; overflow-y:auto; }
.tcf-modal-inner h3 { margin:0 0 16px; font-size:18px; }

.tcf-breadcrumb { font-size:13px; color:var(--tc-muted); margin-bottom:20px; display:flex; align-items:center; gap:4px; flex-wrap:wrap; }
.tcf-breadcrumb a { color:var(--tc-muted); }
.tcf-breadcrumb a:hover { color:var(--tc-red); text-decoration:none; }
.tcf-bc-sep { opacity:.5; }

.tcf-btn { display:inline-flex; align-items:center; gap:6px; padding:9px 20px; border-radius:var(--r-sm); font-size:14px; font-weight:600; cursor:pointer; border:1.5px solid transparent; text-decoration:none !important; transition:all .2s; font-family:var(--font); }
.tcf-btn-new { background:var(--tc-red); color:#fff !important; border-color:var(--tc-red); }
.tcf-btn-new:hover { background:var(--tc-red-dark); }
.tcf-btn-ghost { background:transparent; color:var(--tc-mid) !important; border-color:var(--tc-border); }
.tcf-btn-ghost:hover { border-color:var(--tc-red); color:var(--tc-red) !important; }

.tcf-search-form { display:flex; gap:8px; margin-bottom:20px; }
.tcf-search-input { flex:1; padding:10px 14px; border:1.5px solid var(--tc-border); border-radius:var(--r-sm); font-size:14px; font-family:var(--font); }
.tcf-search-input:focus { outline:none; border-color:var(--tc-red); }

.tcf-pagination,.tcp-pagination { display:flex; gap:4px; margin:24px 0; flex-wrap:wrap; }
.tcf-page-btn,.tcp-page-btn { min-width:36px; height:36px; display:inline-flex; align-items:center; justify-content:center; border:1.5px solid var(--tc-border); border-radius:var(--r-sm); font-size:14px; color:var(--tc-mid); text-decoration:none !important; transition:all .2s; }
.tcf-page-btn:hover,.tcf-page-active,.tcp-page-btn:hover,.tcp-page-active { background:var(--tc-red); border-color:var(--tc-red); color:#fff !important; }

.tcf-avatar { border-radius:50%; display:block; }

.tcf-new-topic-view .tcf-page-title,.tcf-search-view .tcf-page-title { margin-bottom:24px; }
.tcf-profile-view .tcf-profile-card { display:flex; gap:20px; background:var(--tc-white); border:1px solid var(--tc-border); border-top:3px solid var(--tc-red); border-radius:var(--r); padding:24px; margin-bottom:24px; }

/* ══════════════════════════════════════════════════════════
   SUBMIT PAGE  (.tcp-submit-page)
══════════════════════════════════════════════════════════ */

/* Auth gate fallback */
.tcp-auth-gate { text-align:center; padding:80px 24px; max-width:480px; margin:0 auto; }
.tcp-auth-gate-icon { font-size:48px; margin-bottom:16px; }
.tcp-auth-gate-heading { font-size:26px; font-weight:700; color:var(--tc-slate); margin:0 0 10px; }
.tcp-auth-gate-sub { font-size:15px; color:var(--tc-muted); margin:0 0 28px; line-height:1.6; }
.tcp-auth-gate-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.tcp-btn-lg { padding:13px 28px !important; font-size:15px !important; }
.tcp-btn-outline { background:transparent; color:var(--tc-red) !important; border:2px solid var(--tc-red) !important; }
.tcp-btn-outline:hover { background:var(--tc-red); color:#fff !important; }

/* Hero banner */
.tcp-submit-hero { background:linear-gradient(135deg,var(--tc-slate) 0%,#2d3748 100%); padding:40px 24px; }
.tcp-submit-hero-inner { max-width:1100px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.tcp-submit-badge { display:inline-block; background:rgba(201,151,42,.18); color:#e8c060; border:1px solid rgba(201,151,42,.3); border-radius:20px; padding:4px 13px; font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; margin-bottom:10px; }
.tcp-submit-title { font-size:clamp(22px,3vw,34px); font-weight:700; color:#fff; margin:0 0 8px; line-height:1.2; }
.tcp-submit-subtitle { font-size:15px; color:rgba(255,255,255,.7); margin:0; line-height:1.5; }
.tcp-submit-hero-user { display:flex; align-items:center; gap:12px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); border-radius:var(--r); padding:12px 18px; flex-shrink:0; }
.tcp-submit-avatar { width:44px !important; height:44px !important; border-radius:50% !important; object-fit:cover; }
.tcp-submit-user-name { display:block; font-size:14px; font-weight:700; color:#fff; }
.tcp-submit-user-role { display:block; font-size:11px; color:rgba(255,255,255,.55); margin-top:2px; }

/* Body layout */
.tcp-submit-body { background:var(--tc-bg); padding:40px 24px 80px; }
.tcp-submit-inner { max-width:1100px; margin:0 auto; display:grid; grid-template-columns:220px 1fr; gap:32px; align-items:start; }

/* Sidebar nav */
.tcp-submit-sidebar-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--tc-muted); margin:0 0 10px; }
.tcp-submit-nav { display:flex; flex-direction:column; gap:4px; margin-bottom:24px; }
.tcp-snav-item { display:flex; align-items:center; justify-content:space-between; padding:10px 14px; border-radius:var(--r-sm); font-size:14px; font-weight:600; color:var(--tc-mid); text-decoration:none !important; transition:all .18s; border:1.5px solid transparent; }
.tcp-snav-item:hover { background:var(--tc-white); color:var(--tc-red); border-color:var(--tc-border); }
.tcp-snav-item.tcp-snav-active { background:var(--tc-red); color:#fff !important; border-color:var(--tc-red); }
.tcp-snav-arrow { opacity:.7; font-size:12px; }

/* Tips card */
.tcp-submit-tips { background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); padding:18px; }
.tcp-tips-heading { font-size:13px; font-weight:700; color:var(--tc-slate); margin:0 0 12px; }
.tcp-tips-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; }
.tcp-tips-list li { font-size:13px; color:var(--tc-mid); padding-left:18px; position:relative; line-height:1.4; }
.tcp-tips-list li::before { content:'✓'; position:absolute; left:0; color:var(--tc-green); font-weight:700; }

/* Main form panel */
.tcp-submit-main { background:var(--tc-white); border:1px solid var(--tc-border); border-radius:var(--r); padding:32px; }
.tcp-submit-main .tcp-submit-wrap { margin:0; padding:0; }
.tcp-submit-main .tcp-submit-form { max-width:100%; }
/* Hide tab row inside the template — sidebar handles navigation */
.tcp-submit-main .tcp-submit-tabs { display:none; }

/* Input / select polish */
.tcp-input,.tcp-select,.tcp-textarea { width:100%; padding:10px 14px; border:1.5px solid var(--tc-border); border-radius:var(--r-sm); font-size:14px; font-family:var(--font); color:var(--tc-slate); background:var(--tc-white); transition:border-color .18s,box-shadow .18s; box-sizing:border-box; }
.tcp-input:focus,.tcp-select:focus,.tcp-textarea:focus { outline:none; border-color:var(--tc-red); box-shadow:0 0 0 3px rgba(139,26,26,.1); }
.tcp-textarea { resize:vertical; min-height:140px; }
.req { color:var(--tc-red); }

/* ── Responsive ─────────────────────────────────────────── */
@media(max-width:900px) {
    .tcp-submit-inner { grid-template-columns:1fr; }
    .tcp-submit-nav { flex-direction:row; flex-wrap:wrap; }
    .tcp-snav-item { flex:1 1 auto; justify-content:center; }
    .tcp-snav-arrow { display:none; }
    .tcp-widget-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:640px) {
    .tcp-widget-grid { grid-template-columns:1fr; }
    .tcp-card-grid,.tcp-dir-grid { grid-template-columns:1fr; }
        .tce-item { flex-wrap: wrap; }
    .tce-item-date { width: 100%; flex-direction: row; padding: 10px 16px; gap: 10px; justify-content: flex-start; border-radius: 12px 12px 0 0; }
    .tce-idate-day { font-size: 22px; letter-spacing: 0; }
    .tce-idate-range { border-top: none; padding-top: 0; margin-top: 0; }
    .tce-item-thumb { width: 100%; height: 160px; }
    .tce-item-thumb img { min-height: 160px; }
    .tcp-biz-grid { grid-template-columns:1fr; }
    .tcb-loc-bar { flex-direction:column; align-items:stretch; gap:12px; }
    .tcb-loc-inner { justify-content:space-between; }
    .tcb-loc-filters { flex-direction:column; }
    .tcb-loc-filters input, .tcb-loc-filters select { width:100%; box-sizing:border-box; }
    .tcp-news-card { flex-direction:column; }
    .tcp-news-img img { width:100%; height:160px; }
    .tcf-category-row { grid-template-columns:44px 1fr; }
    .tcf-cat-counts,.tcf-cat-last { display:none; }
    .tcf-topic-list-header { display:none; }
    .tcf-topic-row { grid-template-columns:1fr; }
    .tcf-topic-replies,.tcf-topic-views,.tcf-topic-last { display:none; }
    .tcf-post { flex-direction:column; }
    .tcf-post-sidebar { width:100%; flex-direction:row; border-right:none; border-bottom:1px solid var(--tc-border); padding:12px 16px; justify-content:flex-start; }
    /* Submit page mobile */
    .tcp-submit-hero { padding:28px 16px; }
    .tcp-submit-hero-user { display:none; }
    .tcp-submit-body { padding:24px 16px 60px; }
    .tcp-submit-main { padding:20px 16px; }
    .tcp-submit-inner { gap:20px; }
    .tcp-submit-nav { gap:6px; }
    .tcp-snav-item { padding:9px 10px; font-size:13px; }
}
