/* ─────────────────────────────────────────────────────────────
   Areno Pulse — Public portal (extra premium)
   Keep this file small & focused. Uses tokens from pulse.css.
   ───────────────────────────────────────────────────────────── */

/* Header */
.pub-header{background:rgba(245,247,251,.92);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;backdrop-filter:blur(12px)}
body.theme-dark .pub-header{background:rgba(15,20,25,.86)}
.pub-header-inner{max-width:1040px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.pub-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}
.pub-brand-mark{height:28px;width:28px;display:block}
.pub-brand-text{font-size:14px;font-weight:900;letter-spacing:-.02em}
.pub-brand-text b{color:var(--accent)}
.pub-nav{display:flex;align-items:center;gap:6px}

/* Main */
.pub-main{max-width:1040px;margin:0 auto;padding:20px 16px 40px}
.pub-main--portal{max-width:1100px;padding-top:14px}
.pub-main--home{padding-bottom:40px}
@media(max-width:680px){
  .pub-main--home{padding-bottom:calc(92px + env(safe-area-inset-bottom))}
}

/* Footer */
.pub-footer{border-top:1px solid var(--border);padding:20px 16px;text-align:center;font-size:12px;color:var(--muted)}
.pub-footer a{color:var(--accent);text-decoration:none}

/* Home hero */
.ph-hero{padding:34px 0 18px;text-align:center}
.ph-hero-title{font-size:clamp(30px,5vw,46px);font-weight:950;letter-spacing:-.04em;line-height:1.06;margin:0}
.ph-hero-title span{color:var(--accent)}
.ph-hero-sub{font-size:16px;color:var(--muted);margin:12px auto 0;max-width:560px;line-height:1.55}
.ph-hero-cta{display:flex;justify-content:center;gap:10px;margin-top:18px;flex-wrap:wrap}
@media(max-width:520px){
  .ph-hero{padding:22px 0 12px}
  .ph-hero-sub{font-size:14px;margin-top:10px}
  .ph-hero-cta{margin-top:12px}
  .ph-hero-cta .btn{width:100%;max-width:360px}
}

/* Home quick microcards + search */
.ph-quick{margin-top:6px}

/* Use flex so 3 cards stay centered and wrap nicely (grid with 4 cols left an empty column). */
.ph-microgrid{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:10px}
.ph-microcard{flex:1 1 260px;max-width:360px}
@media(max-width:860px){.ph-microcard{max-width:520px}}
@media(max-width:680px){
  /* On mobile, microcards move into a bottom bar (more premium + saves vertical space) */
  .pub-main--home .ph-microgrid{display:none}
}

/* Home bottom action bar (mobile only) */
.ph-homebar{display:none}
@media(max-width:680px){
  .ph-homebar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;gap:8px;justify-content:space-around;align-items:stretch;padding:10px 10px calc(10px + env(safe-area-inset-bottom));background:rgba(245,247,251,.92);backdrop-filter:blur(12px);border-top:1px solid var(--border)}
}
.ph-homebar-item{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 8px;border-radius:16px;border:1px solid transparent;text-decoration:none;color:var(--muted);position:relative}
.ph-homebar-item:hover{background:rgba(15,23,42,.03)}
.ph-homebar-item .i{width:18px;height:18px}
.ph-homebar-item.is-disabled{opacity:.5;pointer-events:none}
.ph-homebar-ic{display:grid;place-items:center}
.ph-homebar-tx{font-size:11px;font-weight:900;letter-spacing:-.01em;line-height:1.05;white-space:nowrap}
.ph-homebar-badge{position:absolute;top:8px;right:10px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;font-size:10px;font-weight:950;display:grid;place-items:center;border:1px solid var(--border);background:var(--card);color:var(--text);opacity:.9}

.ph-homebar-item--reg{background:rgba(37,99,235,.06);border-color:rgba(37,99,235,.14)}
.ph-homebar-item--live{background:rgba(220,38,38,.05);border-color:rgba(220,38,38,.14)}
.ph-homebar-item--up{background:rgba(245,158,11,.05);border-color:rgba(245,158,11,.16)}

.ph-microcard{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:18px;background:var(--card);text-decoration:none;color:var(--text);cursor:pointer;transition:transform .14s, box-shadow .14s, border-color .14s;appearance:none;font:inherit;text-align:left}
.ph-microcard:hover{border-color:rgba(37,99,235,.18);transform:translateY(-1px);box-shadow:0 12px 26px rgba(15,23,42,.08)}
.ph-microcard.is-disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.ph-microcard.is-disabled:hover{border-color:var(--border)}

.ph-micro-ico{width:36px;height:36px;border-radius:14px;border:1px solid var(--border);background:rgba(15,23,42,.03);display:grid;place-items:center;color:var(--muted);flex-shrink:0}
.ph-micro-ico .i{width:18px;height:18px}
.ph-micro-body{min-width:0;flex:1}
.ph-micro-title{font-size:13px;font-weight:950;letter-spacing:-.01em;line-height:1.05}
.ph-micro-sub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.ph-micro-num{font-size:18px;font-weight:950;color:var(--text);opacity:.85}
@media(max-width:680px){
  .ph-microcard{padding:11px 13px;border-radius:16px}
  .ph-micro-ico{width:34px;height:34px;border-radius:13px}
  .ph-micro-num{font-size:16px}
}

.ph-microcard--search .ph-micro-num{opacity:.55}

.ph-microcard--live .ph-micro-ico{background:rgba(220,38,38,.06);border-color:rgba(220,38,38,.16)}
.ph-microcard--reg .ph-micro-ico{background:rgba(37,99,235,.06);border-color:rgba(37,99,235,.16)}
.ph-microcard--up .ph-micro-ico{background:rgba(245,158,11,.06);border-color:rgba(245,158,11,.18)}
.ph-microcard--search .ph-micro-ico{background:rgba(16,185,129,.06);border-color:rgba(16,185,129,.18)}

.ph-search{margin-top:12px}
.ph-searchbox{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,.72)}
body.theme-dark .ph-searchbox{background:rgba(15,20,25,.55)}
.ph-search-ico{display:grid;place-items:center;color:var(--muted)}
.ph-search-ico .i{width:18px;height:18px}
.ph-searchbox input{flex:1;min-width:0;border:none;background:transparent;font-size:14px;outline:none;color:var(--text)}
.ph-search-hint{font-size:12px;color:var(--muted);margin-top:6px;padding-left:6px}

.ph-search-empty{margin-top:16px;padding:16px;border:1px dashed var(--border);border-radius:18px;background:rgba(255,255,255,.45);display:flex;gap:12px;align-items:flex-start}
body.theme-dark .ph-search-empty{background:rgba(15,20,25,.35)}
.ph-search-empty b{font-weight:950}

/* Public cards */
.ph-section{margin-top:28px}
.ph-section-title{font-size:16px;font-weight:900;display:flex;align-items:center;gap:8px;margin:0 0 12px}
.ph-live-dot{width:10px;height:10px;border-radius:50%;background:#dc2626;animation:phBlink 1.2s infinite}
@keyframes phBlink{0%,100%{opacity:1}50%{opacity:.35}}

.ph-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(max-width:680px){.ph-grid{grid-template-columns:1fr}}

.ph-card{display:flex;flex-direction:column;gap:6px;padding:16px;border:1px solid var(--border);border-radius:18px;background:var(--card);text-decoration:none;color:var(--text);transition:transform .14s, box-shadow .14s, border-color .14s}
.ph-card:hover{border-color:rgba(37,99,235,.22);transform:translateY(-2px);box-shadow:0 14px 34px rgba(15,23,42,.10)}
.ph-card--live{border-color:rgba(220,38,38,.18);background:linear-gradient(135deg,rgba(220,38,38,.03),transparent)}
.ph-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.ph-card-name{font-size:16px;font-weight:900;letter-spacing:-.01em;margin:0;line-height:1.15}
.ph-card-meta{font-size:13px;color:var(--muted)}
.ph-card-org{font-size:12px;color:var(--muted);margin-top:2px}
.ph-sport{display:inline-block;margin-top:4px;padding:2px 8px;border-radius:10px;font-size:11px;background:rgba(15,23,42,.04);border:1px solid var(--border);color:var(--muted)}

.ph-cta-section{margin-top:40px;padding:30px;text-align:center;border:1px solid var(--border);border-radius:22px;background:linear-gradient(135deg,rgba(37,99,235,.04),rgba(16,185,129,.03))}
.ph-cta-section h2{font-size:20px;font-weight:950;margin:0 0 6px}

/* Status pill */
.hub-status{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:800;padding:3px 9px;border-radius:999px;border:1px solid var(--border);white-space:nowrap}
.hub-status--info{color:#2563eb;background:rgba(37,99,235,.08);border-color:rgba(37,99,235,.20)}
.hub-status--warning{color:#d97706;background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.20)}
.hub-status--danger{color:#dc2626;background:rgba(220,38,38,.08);border-color:rgba(220,38,38,.20)}
.hub-status--success{color:#059669;background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.20)}
.hub-status--muted{color:var(--muted);background:rgba(15,23,42,.04)}

/* Tournament portal */
.pt-hero{position:relative;border:1px solid var(--border);border-radius:22px;overflow:hidden;background:linear-gradient(135deg,rgba(37,99,235,.10),rgba(16,185,129,.08));padding:18px;z-index:0}
.pt-hero::after{content:"";position:absolute;inset:-60px;opacity:.10;background:radial-gradient(circle at 30% 30%, #2563eb 0%, transparent 55%),radial-gradient(circle at 70% 60%, #10b981 0%, transparent 55%);pointer-events:none;z-index:0}
.pt-hero-inner{position:relative;display:flex;flex-direction:column;gap:10px;z-index:1}
.pt-hero-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pt-back{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-weight:800;color:var(--text);padding:8px 10px;border-radius:14px;background:rgba(255,255,255,.60);border:1px solid rgba(15,23,42,.08)}
body.theme-dark .pt-back{background:rgba(15,20,25,.55);border-color:rgba(255,255,255,.10)}
.pt-actions{display:flex;gap:8px}
.pt-iconbtn{width:42px;height:42px;border-radius:16px;border:1px solid rgba(15,23,42,.10);background:rgba(255,255,255,.60);display:grid;place-items:center;cursor:pointer}
body.theme-dark .pt-iconbtn{background:rgba(15,20,25,.55);border-color:rgba(255,255,255,.10)}
.pt-iconbtn:hover{transform:translateY(-1px)}

.pt-title{font-size:clamp(22px,3.8vw,34px);font-weight:950;letter-spacing:-.03em;margin:0;line-height:1.1}
.pt-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:6px;font-size:13px;color:var(--muted)}
.pt-meta span{display:inline-flex;align-items:center;gap:6px}
.pt-desc{font-size:14px;color:var(--muted);margin:6px 0 0;line-height:1.55;max-width:920px}

/* Tabs (single bar only) */
.pt-tabs{display:flex;gap:6px;margin:14px 0 14px}
.pt-tab{flex:1;min-width:0;padding:10px 12px;border-radius:16px;border:1px solid var(--border);background:rgba(255,255,255,.72);font-size:13px;font-weight:900;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
body.theme-dark .pt-tab{background:rgba(15,20,25,.55)}
.pt-tab.is-active{color:var(--text);border-color:rgba(37,99,235,.22);background:rgba(37,99,235,.10)}

/* Mobile: wrap tabs and keep CTA inside viewport */
@media(max-width:520px){
  .pt-tabs{flex-wrap:wrap}
  .pt-tab{flex:1 1 calc(50% - 6px)}
  .pt-tab--cta{flex:1 1 100%}
}

.pt-panel{animation:ptFade .15s ease}
@keyframes ptFade{from{opacity:0}to{opacity:1}}
.pt-empty{padding:26px;text-align:center;color:var(--muted);font-size:14px;border:1px dashed var(--border);border-radius:18px;background:rgba(255,255,255,.45)}
body.theme-dark .pt-empty{background:rgba(15,20,25,.35)}

/* Matches */
.pt-day{margin-bottom:16px}
.pt-day-header{font-size:12px;font-weight:900;padding:8px 12px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.72);display:inline-flex;gap:8px;align-items:center}
body.theme-dark .pt-day-header{background:rgba(15,20,25,.55)}

.pt-match{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--border);border-radius:18px;margin-top:8px;background:var(--card)}
.pt-match--live{border-color:rgba(220,38,38,.18);background:linear-gradient(135deg,rgba(220,38,38,.03),transparent)}
.pt-match--done{opacity:.82}

.pt-match-time{flex:0 0 58px;text-align:center;font-weight:950;font-size:14px;color:var(--muted)}
.pt-live-badge{font-size:10px;font-weight:950;color:#dc2626;padding:2px 8px;border-radius:999px;background:rgba(220,38,38,.08);border:1px solid rgba(220,38,38,.20);animation:phBlink 1.2s infinite}

.pt-match-teams{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.pt-side{display:flex;align-items:center;gap:10px;min-width:0;flex:1}
.pt-side.right{justify-content:flex-end}
.pt-team{font-weight:900;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}
.pt-team.muted{font-weight:800;color:var(--muted)}

.pt-team-logo{width:28px;height:28px;border-radius:10px;border:1px solid var(--border);background:rgba(15,23,42,.04);object-fit:cover;flex-shrink:0}
.pt-team-initials{width:28px;height:28px;border-radius:10px;border:1px solid var(--border);background:rgba(15,23,42,.04);display:grid;place-items:center;font-size:11px;font-weight:950;color:var(--muted);flex-shrink:0}

.pt-score{font-weight:950;font-size:15px;padding:4px 10px;border-radius:14px;background:rgba(15,23,42,.05);border:1px solid var(--border);white-space:nowrap}
.pt-score--live{background:rgba(220,38,38,.08);border-color:rgba(220,38,38,.18);color:#dc2626}
.pt-vs{color:var(--muted);font-size:11px;font-weight:900}

.pt-match-info{display:flex;gap:8px;font-size:11px;color:var(--muted);flex-shrink:0;align-items:center}
.pt-pill{padding:2px 8px;border-radius:999px;border:1px solid rgba(37,99,235,.14);background:rgba(37,99,235,.06)}

@media(max-width:680px){
  .pt-match{flex-direction:column;align-items:stretch}
  .pt-match-time{flex:none;text-align:left}
  /* Keep teams on a single line (home vs away), even on mobile. */
  .pt-match-teams{flex-direction:row;align-items:center;gap:8px}
  .pt-side{gap:8px}
  .pt-side.right{justify-content:flex-end}
  .pt-team{max-width:none}
}

/* Standings */
.pt-standings-section{margin-top:14px}
.pt-standings-title{font-size:14px;font-weight:950;margin:0 0 10px}
.pt-table{width:100%;border-collapse:collapse;font-size:13px}
.pt-table th{text-align:center;padding:10px 8px;font-size:11px;color:var(--muted);border-bottom:2px solid var(--border)}
.pt-table th:nth-child(2){text-align:left}
.pt-table td{text-align:center;padding:10px 8px;border-bottom:1px solid var(--border)}
.pt-team-cell{text-align:left!important}
.pt-pos{font-weight:950;color:var(--muted);width:30px}
.pt-pts{font-size:14px;font-weight:950;color:var(--accent)}
.pt-row--top td{background:rgba(37,99,235,.03)}

/* Standings on mobile: hide less important columns to avoid horizontal scrolling */
@media(max-width:640px){
  .pt-table{font-size:12px}
  .pt-table th, .pt-table td{padding:8px 6px}
  .pt-table th:nth-child(5), .pt-table td:nth-child(5),
  .pt-table th:nth-child(6), .pt-table td:nth-child(6),
  .pt-table th:nth-child(7), .pt-table td:nth-child(7){display:none}
}

/* Teams */
.pt-team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:760px){.pt-team-grid{grid-template-columns:repeat(2,1fr)}}
.pt-team-card{padding:12px;border:1px solid var(--border);border-radius:18px;background:var(--card);display:flex;align-items:center;gap:10px}
.pt-team-card:hover{border-color:rgba(37,99,235,.18)}
.pt-team-card-name{font-weight:950;letter-spacing:-.01em;line-height:1.1}
.pt-team-card-meta{font-size:12px;color:var(--muted);margin-top:2px}


/* Brand mark in portal hero */
.pt-brand{display:flex;align-items:center;gap:10px;min-width:0}
.pt-brand img{width:34px;height:34px;display:block}
@media (max-width:640px){.pt-brand img{width:30px;height:30px}}

.pt-standings-subtitle{margin:10px 0 8px 0;font-weight:900;display:flex;align-items:center;gap:8px;color:var(--text);opacity:.9}

/* Registration CTA tab */
.pt-tab--cta{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;color:#fff!important;border-color:transparent!important;border-radius:20px!important;font-weight:700}
.pt-tab--cta:hover{opacity:.9;transform:translateY(-1px)}
