/* ═══════════════════════════════════════════════════════════════
   TDC PORTAL — Observer / Reviewer / Admin Dashboard
═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700&family=DM+Sans:wght@300;400;500&display=swap');

.tdcp-wrap { font-family:'DM Sans',sans-serif; color:#1c1c1c; max-width:1100px; margin:0 auto; padding:0 1rem 3rem; }

/* ── LOGIN PAGE ──────────────────────────────────────────────── */
.tdcp-login-wrap { display:flex; flex-direction:column; align-items:center; padding:3rem 1rem; gap:2rem; }
.tdcp-login-card { background:#fff; border:1px solid #dce8dc; border-radius:16px; padding:2.5rem; width:100%; max-width:420px; box-shadow:0 4px 32px rgba(26,74,46,0.08); }
.tdcp-login-header { text-align:center; margin-bottom:1.75rem; }
.tdcp-login-icon { font-size:3rem; margin-bottom:0.5rem; }
.tdcp-login-title { font-family:'Playfair Display',serif; font-size:1.6rem; color:#1a4a2e; margin:0 0 0.25rem; }
.tdcp-login-sub { font-size:0.8rem; color:#81c784; text-transform:uppercase; letter-spacing:0.08em; }
.tdcp-alert { border-radius:8px; padding:0.75rem 1rem; font-size:0.875rem; margin-bottom:1rem; }
.tdcp-alert--error { background:#ffebee; border:1px solid #ef9a9a; color:#c62828; }
.tdcp-login-form .tdcp-field { margin-bottom:1rem; }
.tdcp-label { display:block; font-size:0.825rem; font-weight:500; color:#333; margin-bottom:0.35rem; }
.tdcp-input { width:100%; padding:0.65rem 0.9rem; border:1.5px solid #d4e8d4; border-radius:8px; font-family:'DM Sans',sans-serif; font-size:0.9rem; color:#1c1c1c; background:#fafaf8; transition:border-color 0.2s,box-shadow 0.2s; box-sizing:border-box; }
.tdcp-input:focus { outline:none; border-color:#2e7d32; box-shadow:0 0 0 3px rgba(46,125,50,0.1); }
.tdcp-pass-wrap { position:relative; }
.tdcp-pass-wrap .tdcp-input { padding-right:2.5rem; }
.tdcp-eye-btn { position:absolute; right:10px; top:50%; transform:translateY(-50%); background:none; border:none; cursor:pointer; font-size:1rem; }
.tdcp-login-btn { width:100%; background:#1a4a2e; color:#fff; border:none; border-radius:8px; padding:0.85rem; font-family:'DM Sans',sans-serif; font-size:0.95rem; font-weight:500; cursor:pointer; margin-top:0.5rem; transition:background 0.2s; }
.tdcp-login-btn:hover { background:#2e7d32; }
.tdcp-login-footer { text-align:center; margin-top:1.5rem; font-size:0.8rem; color:#888; line-height:1.6; }
.tdcp-back-link { color:#2e7d32; font-size:0.8rem; }
.tdcp-login-roles { display:grid; grid-template-columns:repeat(3,1fr); gap:0.75rem; max-width:520px; width:100%; }
.tdcp-role-card { background:#f0f7f0; border:1px solid #d4e8d4; border-radius:10px; padding:1rem; display:flex; gap:0.6rem; align-items:flex-start; font-size:0.78rem; color:#444; line-height:1.5; }
.tdcp-role-icon { font-size:1.25rem; flex-shrink:0; }
@media(max-width:560px){ .tdcp-login-roles { grid-template-columns:1fr; } }

/* ── PORTAL HEADER ───────────────────────────────────────────── */
.tdcp-portal-header { background:#1a4a2e; color:#f1f8e9; border-radius:12px; padding:1rem 1.5rem; display:flex; justify-content:space-between; align-items:center; margin-bottom:1rem; flex-wrap:wrap; gap:1rem; }
.tdcp-portal-header__left { display:flex; align-items:center; gap:0.75rem; }
.tdcp-portal-logo { font-size:1.75rem; }
.tdcp-portal-title { font-family:'Playfair Display',serif; font-size:1.1rem; color:#f1f8e9; line-height:1; }
.tdcp-portal-sub { font-size:0.72rem; color:#81c784; text-transform:uppercase; letter-spacing:0.08em; }
.tdcp-portal-header__right { display:flex; align-items:center; gap:1rem; }
.tdcp-user-chip { display:flex; align-items:center; gap:0.6rem; }
.tdcp-user-avatar { width:36px; height:36px; border-radius:50%; background:#c8a84b; color:#1a0e00; font-weight:700; font-size:0.9rem; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.tdcp-user-name { font-size:0.875rem; font-weight:500; color:#f1f8e9; line-height:1; }
.tdcp-user-role { font-size:0.7rem; color:#81c784; }
.tdcp-logout-btn { background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.2); color:#f1f8e9; padding:0.4rem 1rem; border-radius:6px; font-size:0.8rem; text-decoration:none; transition:background 0.2s; white-space:nowrap; }
.tdcp-logout-btn:hover { background:rgba(255,255,255,0.18); }

/* ── TAB NAV ─────────────────────────────────────────────────── */
.tdcp-nav { display:flex; gap:0.25rem; flex-wrap:wrap; background:#fff; border:1px solid #dce8dc; border-radius:10px; padding:0.4rem; margin-bottom:1.25rem; }
.tdcp-nav__link { padding:0.5rem 1rem; border-radius:7px; font-size:0.875rem; font-weight:500; color:#5a5a5a; text-decoration:none; transition:all 0.2s; white-space:nowrap; }
.tdcp-nav__link:hover { background:#f0f7f0; color:#1a4a2e; }
.tdcp-nav__link--active { background:#1a4a2e; color:#fff !important; }

/* ── CONTENT ─────────────────────────────────────────────────── */
.tdcp-content { background:#fff; border:1px solid #dce8dc; border-radius:12px; padding:1.75rem; }
.tdcp-tab-title { font-family:'Playfair Display',serif; font-size:1.5rem; color:#1a4a2e; margin:0 0 1.25rem; display:flex; align-items:center; gap:0.75rem; }
.tdcp-badge { background:#1a4a2e; color:#fff; font-size:0.75rem; font-family:'DM Sans',sans-serif; font-weight:500; padding:0.2rem 0.6rem; border-radius:20px; }
.tdcp-section-title { font-size:1rem; font-weight:500; color:#1a4a2e; margin:1.75rem 0 0.75rem; border-bottom:1px solid #e8f5e9; padding-bottom:0.4rem; }

/* ── STATS GRID ──────────────────────────────────────────────── */
.tdcp-stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:0.875rem; margin-bottom:1.5rem; }
.tdcp-stat-card { background:#f8fdf8; border:1px solid #dce8dc; border-radius:10px; padding:1.1rem; text-align:center; }
.tdcp-stat-num { font-size:2.25rem; font-weight:700; line-height:1; margin-bottom:0.25rem; }
.tdcp-stat-label { font-size:0.72rem; color:#888; text-transform:uppercase; letter-spacing:0.06em; }

/* ── PLATFORM BARS ───────────────────────────────────────────── */
.tdcp-platform-bars { display:flex; flex-direction:column; gap:0.5rem; margin-bottom:1.5rem; }
.tdcp-plat-row { display:grid; grid-template-columns:90px 1fr 40px; align-items:center; gap:0.75rem; font-size:0.85rem; }
.tdcp-plat-name { color:#555; }
.tdcp-plat-bar-wrap { background:#f0f0f0; border-radius:20px; height:8px; }
.tdcp-plat-bar { height:8px; border-radius:20px; transition:width 0.6s ease; min-width:4px; }
.tdcp-plat-count { font-weight:500; color:#1a4a2e; text-align:right; }

/* ── TABLE ───────────────────────────────────────────────────── */
.tdcp-table-wrap { overflow-x:auto; border:1px solid #e8e8e8; border-radius:8px; }
.tdcp-table { width:100%; border-collapse:collapse; font-size:0.825rem; }
.tdcp-table thead tr { background:#f8fdf8; border-bottom:2px solid #dce8dc; }
.tdcp-table th { padding:0.75rem 0.875rem; text-align:left; font-size:0.72rem; text-transform:uppercase; letter-spacing:0.06em; color:#888; font-weight:500; white-space:nowrap; }
.tdcp-table td { padding:0.75rem 0.875rem; border-bottom:1px solid #f0f0f0; vertical-align:middle; }
.tdcp-table tr:last-child td { border-bottom:none; }
.tdcp-table tr:hover td { background:#fafff8; }
.tdcp-table code { background:#f0f7f0; color:#1a4a2e; padding:2px 6px; border-radius:4px; font-size:0.8rem; }
.tdcp-status-pill { color:#fff; font-size:0.7rem; padding:3px 9px; border-radius:20px; white-space:nowrap; font-weight:500; }

/* ── TAB HEADER + SEARCH ─────────────────────────────────────── */
.tdcp-tab-header { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:1rem; margin-bottom:1.25rem; }
.tdcp-search-form { display:flex; gap:0.5rem; flex-wrap:wrap; }
.tdcp-search-input { padding:0.5rem 0.875rem; border:1.5px solid #dce8dc; border-radius:7px; font-size:0.875rem; min-width:220px; }
.tdcp-search-btn { background:#1a4a2e; color:#fff; border:none; border-radius:7px; padding:0.5rem 1rem; font-size:0.875rem; cursor:pointer; }
.tdcp-clear-btn { background:#f5f5f5; color:#555; border:1px solid #ddd; border-radius:7px; padding:0.5rem 1rem; font-size:0.875rem; text-decoration:none; }

/* ── FILTER TABS ─────────────────────────────────────────────── */
.tdcp-filter-tabs { display:flex; gap:0.4rem; flex-wrap:wrap; }
.tdcp-filter-tab { padding:0.35rem 0.875rem; border:1px solid #dce8dc; border-radius:20px; font-size:0.8rem; color:#555; text-decoration:none; background:#fff; transition:all 0.2s; }
.tdcp-filter-tab.active { background:#1a4a2e; color:#fff; border-color:#1a4a2e; }

/* ── SUBMISSION CARDS ────────────────────────────────────────── */
.tdcp-sub-card { background:#fafafa; border:1px solid #e8e8e8; border-radius:10px; padding:1.25rem; margin-bottom:1rem; }
.tdcp-sub-card__head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:0.75rem; gap:1rem; }
.tdcp-score-big { font-size:1.75rem; font-weight:700; color:#1a4a2e; text-align:right; white-space:nowrap; }
.tdcp-score-big span { font-size:0.75rem; font-weight:400; color:#888; display:block; }
.tdcp-sub-card__post { font-size:0.825rem; color:#555; margin-bottom:0.75rem; word-break:break-all; }
.tdcp-sub-card__post a { color:#2e7d32; }
.tdcp-sub-card__stats { display:flex; flex-wrap:wrap; gap:0.75rem; background:#f0f7f0; border-radius:7px; padding:0.6rem 0.875rem; margin-bottom:0.75rem; font-size:0.825rem; color:#444; }
.tdcp-sub-card__stats strong { color:#1a4a2e; }
.tdcp-sub-card__edit { border-top:1px dashed #dce8dc; padding-top:0.875rem; }
.tdcp-edit-row { display:flex; flex-wrap:wrap; gap:0.75rem; margin-bottom:0.75rem; }
.tdcp-edit-row label { font-size:0.75rem; color:#555; display:flex; flex-direction:column; gap:3px; }
.tdcp-edit-input { padding:0.35rem 0.6rem; border:1px solid #ddd; border-radius:6px; font-size:0.85rem; width:100px; font-family:'DM Sans',sans-serif; }
select.tdcp-edit-input { width:130px; }
.tdcp-edit-textarea { width:100%; min-height:60px; padding:0.5rem; border:1px solid #ddd; border-radius:6px; font-size:0.825rem; font-family:'DM Sans',sans-serif; resize:vertical; margin-bottom:0.75rem; }
.tdcp-save-btn { background:#2e7d32; color:#fff; border:none; border-radius:7px; padding:0.5rem 1.25rem; font-size:0.85rem; cursor:pointer; transition:background 0.2s; }
.tdcp-save-btn:hover { background:#1a4a2e; }
.tdcp-save-msg { font-size:0.8rem; margin-left:0.75rem; }
.tdcp-judge-notes-ro { font-size:0.82rem; color:#666; background:#fffde7; border-left:3px solid #ffd54f; padding:0.5rem 0.75rem; border-radius:0 6px 6px 0; }

/* ── LEADERBOARD ─────────────────────────────────────────────── */
.tdcp-leaderboard { display:flex; flex-direction:column; gap:0.5rem; }
.tdcp-lb-row { display:grid; grid-template-columns:44px 1fr 180px 80px 100px; align-items:center; gap:1rem; background:#fafafa; border:1px solid #e8e8e8; border-radius:10px; padding:0.875rem 1rem; }
.tdcp-lb-row--gold { background:#fffde7; border-color:#ffd54f; }
.tdcp-lb-row--silver { background:#fafafa; border-color:#e0e0e0; }
.tdcp-lb-row--bronze { background:#fff8f3; border-color:#ffccbc; }
.tdcp-lb-rank { font-size:1.5rem; text-align:center; }
.tdcp-lb-name { font-weight:500; color:#1a4a2e; font-size:0.925rem; }
.tdcp-lb-dept { font-size:0.78rem; color:#888; }
.tdcp-lb-stats { display:flex; flex-wrap:wrap; gap:0.5rem; font-size:0.8rem; color:#555; }
.tdcp-lb-score { font-size:1.25rem; font-weight:700; color:#1a4a2e; text-align:right; }
.tdcp-lb-score span { font-size:0.7rem; font-weight:400; color:#888; display:block; }
.tdcp-lb-link { font-size:0.78rem; color:#2e7d32; text-decoration:none; white-space:nowrap; text-align:right; }
@media(max-width:700px){ .tdcp-lb-row { grid-template-columns:40px 1fr auto; } .tdcp-lb-stats,.tdcp-lb-score,.tdcp-lb-link { display:none; } }

/* ── ACCOUNTS TAB ────────────────────────────────────────────── */
.tdcp-account-create { background:#f0f7f0; border:1px solid #dce8dc; border-radius:10px; padding:1.25rem; margin-bottom:1.5rem; }
.tdcp-create-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:0.875rem; margin-bottom:1rem; }
.tdcp-create-grid .tdcp-field { margin:0; }
.tdcp-create-btn { background:#1a4a2e; color:#fff; border:none; border-radius:8px; padding:0.65rem 1.5rem; font-size:0.9rem; font-weight:500; cursor:pointer; }
.tdcp-create-btn:hover { background:#2e7d32; }
.tdcp-msg { background:#e8f5e9; border:1px solid #a5d6a7; color:#1a4a2e; border-radius:8px; padding:0.75rem 1rem; font-size:0.875rem; margin-bottom:1rem; }
.tdcp-role-pill { color:#fff; font-size:0.7rem; padding:3px 9px; border-radius:20px; font-weight:500; }
.tdcp-pill-green { background:#2e7d32; color:#fff; font-size:0.75rem; padding:3px 9px; border-radius:20px; }
.tdcp-pill-red { background:#c62828; color:#fff; font-size:0.75rem; padding:3px 9px; border-radius:20px; }
.tdcp-action-btns { display:flex; gap:0.4rem; flex-wrap:wrap; align-items:center; }
.tdcp-act-btn { background:#f5f5f5; border:1px solid #ddd; color:#333; padding:0.3rem 0.7rem; border-radius:5px; font-size:0.75rem; cursor:pointer; text-decoration:none; white-space:nowrap; }
.tdcp-act-btn:hover { background:#e8e8e8; }
.tdcp-act-btn--danger { color:#c62828; border-color:#ef9a9a; }
.tdcp-act-btn--danger:hover { background:#ffebee; }
.tdcp-reset-detail summary { cursor:pointer; }
.tdcp-reset-detail[open] summary { color:#1a4a2e; }

/* ── EXPORT ──────────────────────────────────────────────────── */
.tdcp-export-cards { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; max-width:600px; }
.tdcp-export-card { background:#f0f7f0; border:1px solid #dce8dc; border-radius:12px; padding:1.5rem; }
.tdcp-export-icon { font-size:2rem; margin-bottom:0.5rem; }
.tdcp-export-card h3 { font-size:1rem; color:#1a4a2e; margin:0 0 0.4rem; }
.tdcp-export-card p { font-size:0.825rem; color:#666; margin:0 0 1rem; line-height:1.6; }
.tdcp-export-btn { background:#1a4a2e; color:#fff; border:none; border-radius:7px; padding:0.6rem 1.25rem; font-size:0.875rem; cursor:pointer; }
.tdcp-export-btn:hover { background:#2e7d32; }
@media(max-width:500px){ .tdcp-export-cards { grid-template-columns:1fr; } }

/* ── EMPTY STATE ─────────────────────────────────────────────── */
.tdcp-empty { text-align:center; padding:3rem; color:#888; font-size:0.925rem; }
.tdcp-empty--denied { color:#c62828; }

/* ── LOGIN: Tea Board logo ───────────────────────────────────── */
.tdcp-login-logo-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 1rem;
}
.tdcp-login-tb-logo {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: #fff;
  padding: 4px;
  box-shadow: 0 0 0 3px #c8a84b, 0 4px 20px rgba(26,74,46,0.15);
  object-fit: contain;
  display: block;
}

/* ── Portal header Tea Board logo ───────────────────────────── */
.tdcp-portal-header-logo {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  padding: 2px;
  box-shadow: 0 0 0 1.5px rgba(200,168,75,0.6);
  object-fit: contain;
  flex-shrink: 0;
}

/* Fix logout button — was styled as <a>, now it's <button> */
.tdcp-logout-btn {
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.25);
  color: #f1f8e9;
  padding: 0.4rem 1rem;
  border-radius: 6px;
  font-size: 0.8rem;
  font-family: 'DM Sans', sans-serif;
  cursor: pointer;
  transition: background 0.2s;
  white-space: nowrap;
  text-decoration: none;
  display: inline-block;
}
.tdcp-logout-btn:hover { background: rgba(255,255,255,0.2); color: #fff; }
