/* hub2.css - RamaChess Grandmaster Games portal styles */

:root[data-theme="dark"]{
  --bg:#0a0a0a; --panel:#161616; --panel-2:#1f1f1f; --line:#2a2a2a;
  --text:#f5f5f5; --muted:#8e8e93; --muted-2:#636366;
  --accent:#34c759; --accent-2:#28a745;
  --shadow-lg:0 16px 50px rgba(0,0,0,0.6);
  --shadow-md:0 8px 28px rgba(0,0,0,0.5);
  --scrim:rgba(0,0,0,0.78);
}
:root[data-theme="light"]{
  --bg:#fafafa; --panel:#ffffff; --panel-2:#f3f3f3; --line:#e5e5e5;
  --text:#111; --muted:#666; --muted-2:#999;
  --accent:#0a7c2c; --accent-2:#0a6224;
  --shadow-lg:0 12px 36px rgba(0,0,0,0.10);
  --shadow-md:0 8px 24px rgba(0,0,0,0.08);
  --scrim:rgba(0,0,0,0.5);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'SF Pro',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;transition:background .15s,color .15s;overflow-x:hidden}
.wrap{max-width:1100px;margin:0 auto;padding:14px}

/* ===== TOP BAR ===== */
.top{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line);font-size:13px;background:var(--bg);position:sticky;top:0;z-index:50;flex-wrap:nowrap}
.top a{color:var(--text);text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:5px}
.top .brand img{width:22px;height:22px;border-radius:6px;vertical-align:middle}
.top .h{color:var(--muted);font-weight:400;flex-shrink:0}
.top .spacer{flex:1}
.top .practice-link{color:var(--muted);font-size:12px;font-weight:500}
.top .icon-btn{background:var(--panel);border:1px solid var(--line);color:var(--text);width:34px;height:34px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;padding:0}
.top .icon-btn:active{background:var(--panel-2)}
.top .icon-btn svg{width:18px;height:18px}
.top .theme-tog{font-size:16px;line-height:1}

/* On narrow screens hide Grandmasters/breadcrumb text but keep brand */
@media(max-width:480px){
  .top .h, .top .crumb-text{display:none}
}

/* ===== HERO ===== */
.hero{font-size:24px;letter-spacing:-0.4px;margin:14px 0 6px;font-weight:700}
.hero small{font-weight:400;color:var(--muted);font-size:14px}
.tagline{color:var(--muted);font-size:14px;margin-bottom:16px;line-height:1.55}

/* ===== HERO STATS ===== */
.hero-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:14px 0 24px}
.hs{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px 8px;text-align:center}
.hs-v{font-size:18px;font-weight:700;letter-spacing:-0.4px}
.hs-l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.6px;margin-top:2px}
@media(max-width:560px){
  .hero-stats{grid-template-columns:repeat(3,1fr)}
  .hs-v{font-size:15px}
}

/* ===== SECTION HEADERS ===== */
section{margin-bottom:28px}
h2.sec{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:8px}
h2.sec .bd{background:var(--panel-2);color:var(--muted);padding:1px 7px;border-radius:8px;font-size:10px;letter-spacing:0}

/* ===== FEATURED GM CARDS — 4x4 grid on mobile ===== */
.grid-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}
@media(min-width:600px){.grid-cards{grid-template-columns:repeat(6,1fr);gap:8px}}
@media(min-width:900px){.grid-cards{grid-template-columns:repeat(8,1fr);gap:10px}}

.gcard{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:4px;text-align:center;text-decoration:none;color:var(--text);transition:transform .12s,border-color .12s;display:block}
.gcard:active{transform:scale(0.95)}
.gcard:hover{border-color:var(--accent)}
.gcard img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:5px;background:var(--panel-2);display:block}
.gcard-name{font-size:10.5px;font-weight:600;margin-top:3px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-0.1px}
.gcard-meta{font-size:9px;color:var(--muted);margin-top:1px;line-height:1.2}
.gcard-meta .cn{color:var(--accent);font-weight:600}
@media(min-width:600px){
  .gcard{padding:6px;border-radius:10px}
  .gcard img{border-radius:7px}
  .gcard-name{font-size:11px;margin-top:5px}
  .gcard-meta{font-size:10px;margin-top:2px}
}
@media(min-width:900px){
  .gcard{padding:8px;border-radius:12px}
  .gcard img{border-radius:8px}
  .gcard-name{font-size:12px;margin-top:6px}
}

/* ===== BROWSE TILES ===== */
.section-tiles{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(min-width:600px){.section-tiles{grid-template-columns:repeat(4,1fr)}}
.stile{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:14px;text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:5px;transition:transform .12s,border-color .12s}
.stile:active{transform:scale(0.98)}
.stile:hover{border-color:var(--accent)}
.stile h3{font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:space-between;line-height:1.3}
.stile h3 .arr{color:var(--accent);font-size:13px}
.stile p{font-size:11px;color:var(--muted);line-height:1.4}

/* ===== OPP-CARDS (used for openings/years/events sub-grids) ===== */
.opp-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
@media(min-width:600px){.opp-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.opp-grid{grid-template-columns:repeat(4,1fr)}}
.opp-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px 12px;text-decoration:none;color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;transition:border-color .12s,background .12s;line-height:1.3}
.opp-card:hover{border-color:var(--accent);background:var(--panel-2)}
.opp-card .vs{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.opp-card .cn{color:var(--accent);font-size:12px;font-weight:600;flex-shrink:0;font-family:ui-monospace,monospace}
.opp-card .vs small{color:var(--muted);font-weight:400;font-size:11px;display:block}

/* ===== SECTION NAV TABS (for player section pages) ===== */
.section-nav{display:flex;gap:0;flex-wrap:wrap;margin:8px 0 14px;border-bottom:1px solid var(--line);overflow-x:auto;-webkit-overflow-scrolling:touch}
.section-nav a{padding:9px 14px;font-size:13px;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;font-weight:500;white-space:nowrap;flex-shrink:0}
.section-nav a:hover{color:var(--text)}
.section-nav a.active{color:var(--accent);border-bottom-color:var(--accent)}

/* ===== PLAYER HERO ===== */
.player-hero{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}
.player-hero img{width:88px;height:88px;border-radius:14px;object-fit:cover;background:var(--panel-2);flex-shrink:0}
.player-hero h1{font-size:22px;font-weight:700;letter-spacing:-0.3px;margin-bottom:4px}
.player-hero .bio{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:8px}
.player-hero .stats{display:flex;flex-wrap:wrap;gap:10px 14px;font-size:12px;color:var(--muted)}
.player-hero .stats b{color:var(--text);font-weight:700}

/* ===== COMPACT GAME LIST ===== */
.glist-wrap{margin-top:10px;border-radius:10px;background:var(--panel);border:1px solid var(--line);overflow:hidden}
.glist-head{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.6px;border-bottom:1px solid var(--line);background:var(--panel-2)}
.glist-head .h-yr{width:46px}
.glist-head .h-vs{flex:1}
.glist-head .h-op{width:140px;text-align:right;display:none}
.glist-head .h-ev{width:160px;text-align:right;display:none}
.glist-head .h-res{width:48px;text-align:right;font-family:ui-monospace,monospace}
@media(min-width:760px){.glist-head .h-op,.glist-head .h-ev{display:block}}

.glist{max-height:560px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.grow{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--text);font-size:13px;line-height:1.35;transition:background .1s}
.grow:last-child{border-bottom:none}
.grow:hover{background:var(--panel-2)}
.grow:active{background:var(--line)}
.grow .g-yr{width:46px;color:var(--muted);font-family:ui-monospace,monospace;font-size:12px;flex-shrink:0}
.grow .g-vs{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.grow .g-vs em{color:var(--muted);font-style:normal;font-weight:400;margin:0 4px}
.grow .g-op{width:140px;color:var(--muted);font-size:12px;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;display:none}
.grow .g-ev{width:160px;color:var(--muted);font-size:12px;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;display:none}
.grow .g-res{width:48px;font-family:ui-monospace,monospace;font-size:12px;text-align:right;color:var(--muted);flex-shrink:0}
@media(min-width:760px){.grow .g-op,.grow .g-ev{display:block}}

.glist-meta{padding:9px 14px;border-top:1px solid var(--line);font-size:12px;color:var(--muted);background:var(--panel-2)}

/* ===== SEARCH MODAL ===== */
.modal-scrim{position:fixed;inset:0;background:var(--scrim);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:0}
.modal-scrim.open{display:flex}
.modal{background:var(--panel);width:100%;max-width:760px;max-height:100dvh;height:100dvh;display:flex;flex-direction:column;border-radius:0;box-shadow:var(--shadow-lg)}
@media(min-width:600px){.modal{margin:30px auto;height:auto;max-height:90vh;border-radius:14px}}
.modal-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line);flex-shrink:0}
.modal-head h3{font-size:16px;font-weight:700;flex:1}
.modal-close{background:var(--panel-2);border:none;color:var(--text);width:34px;height:34px;border-radius:8px;font-size:20px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.modal-close:active{background:var(--line)}
.modal-body{padding:14px 16px;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;min-height:0}
.modal-body .search-row{display:flex;flex-direction:column;gap:8px}
@media(min-width:560px){.modal-body .search-row{flex-direction:row;align-items:stretch}}
.pinput{position:relative;flex:1}
/* iOS-safe input: 16px font prevents auto-zoom on focus */
.pinput input{width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--text);padding:11px 12px;border-radius:10px;font-size:16px;font-family:inherit;outline:none;transition:border-color .12s}
.pinput input:focus{border-color:var(--accent)}
.dd{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--panel);border:1px solid var(--line);border-radius:10px;max-height:280px;overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:10;display:none;box-shadow:var(--shadow-md)}
.dd.open{display:block}
.dd-item{padding:9px 14px;cursor:pointer;font-size:14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.dd-item:last-child{border-bottom:none}
.dd-item:active{background:var(--panel-2)}
.dd-item .gm{background:var(--accent);color:white;font-size:9px;font-weight:700;padding:1px 5px;border-radius:4px;letter-spacing:0.3px}
.search-btn{background:var(--accent);color:white;border:none;padding:11px 18px;border-radius:10px;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;flex-shrink:0}
.search-btn:active{background:var(--accent-2)}
#searchResults{margin-top:14px}
#searchResults .result-meta{padding:10px 14px;font-size:13px;color:var(--muted);background:var(--panel-2);border-radius:10px;margin-bottom:6px}
#searchResults .result-list{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}
#searchResults .result-row{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--text);font-size:13px;line-height:1.35}
#searchResults .result-row:last-child{border-bottom:none}
#searchResults .result-row:active{background:var(--panel-2)}
#searchResults .result-row .yr{width:46px;color:var(--muted);font-family:ui-monospace,monospace;font-size:12px;flex-shrink:0}
#searchResults .result-row .ttl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
#searchResults .result-row .res{width:48px;font-family:ui-monospace,monospace;font-size:12px;text-align:right;color:var(--muted);flex-shrink:0}

/* ===== FAQ ===== */
.faq-item{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:11px 14px;margin-bottom:6px}
.faq-item summary{font-weight:600;font-size:13px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';color:var(--accent);font-weight:700}
.faq-item[open] summary::after{content:'\2212'}
.faq-item p{margin-top:8px;color:var(--muted);font-size:12px;line-height:1.55}

/* ===== FOOTER ===== */
footer{padding:20px 14px;text-align:center;color:var(--muted);font-size:11px;border-top:1px solid var(--line);margin-top:30px}

/* ===== GLOBAL COMPACT LIST (alias for .result-row / .list-cards used by year/event/games pages) ===== */
.list-cards{margin-top:10px;border-radius:10px;background:var(--panel);border:1px solid var(--line);max-height:560px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.list-cards > .result-row,
.result-row{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--text);font-size:13px;line-height:1.35;background:var(--panel);transition:background .1s}
.list-cards > .result-row:last-child,
.result-row:last-child{border-bottom:none}
.list-cards > .result-row:hover,
.result-row:hover{background:var(--panel-2)}
.list-cards > .result-row:active,
.result-row:active{background:var(--line)}
.list-cards > .result-row .yr,
.result-row .yr{width:46px;color:var(--muted);font-family:ui-monospace,monospace;font-size:12px;flex-shrink:0}
.list-cards > .result-row .ttl,
.result-row .ttl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.list-cards > .result-row .res,
.result-row .res{width:48px;font-family:ui-monospace,monospace;font-size:12px;text-align:right;color:var(--muted);flex-shrink:0}

/* When used outside of a list-cards wrapper, give result-row a top/bottom border to look like a list */
body > main > .result-row,
main > .result-row{border:1px solid var(--line);border-radius:0}
main > .result-row:first-of-type{border-radius:10px 10px 0 0}
main > .result-row:last-of-type{border-radius:0 0 10px 10px;border-bottom:1px solid var(--line)}

/* Scroll container for very long lists */
.scroll-list{max-height:560px;overflow-y:auto;-webkit-overflow-scrolling:touch}

/* Result meta header */
.result-meta{padding:9px 14px;font-size:12px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-bottom:none;border-radius:10px 10px 0 0;margin-top:14px}

/* Make sure inline pages with result-rows have a consistent look */
main h1.hero + p.tagline + .result-row,
main p.tagline + .result-row{border-top:1px solid var(--line);border-radius:10px 10px 0 0}



/* === Global compatibility: .list-cards / .result-row / .result-meta everywhere === */
.list-cards{margin-top:10px;border-radius:10px;background:var(--panel);border:1px solid var(--line);overflow:hidden;max-height:none}
@media(min-width:760px){.list-cards{}}

.result-meta{padding:10px 14px;font-size:13px;color:var(--muted);background:var(--panel-2);border-radius:10px;margin-bottom:8px;border:1px solid var(--line)}

a.result-row{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--text);font-size:13px;line-height:1.35;transition:background .1s}
a.result-row:last-child{border-bottom:none}
a.result-row:hover{background:var(--panel-2)}
a.result-row:active{background:var(--line)}
a.result-row .yr{width:46px;color:var(--muted);font-family:ui-monospace,monospace;font-size:12px;flex-shrink:0}
a.result-row .ttl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
a.result-row .res{width:54px;font-family:ui-monospace,monospace;font-size:12px;text-align:right;color:var(--muted);flex-shrink:0}

/* Wrapper for very long lists: force a max-height and scroll */
.scroll-list{max-height:680px;overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:10px;border:1px solid var(--line);background:var(--panel)}

/* ===== LCARD (year and event hub rows) ===== */
.list-cards > .lcard,
.lcard{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--text);font-size:14px;line-height:1.35;background:var(--panel);transition:background .1s}
.list-cards > .lcard:last-child,
.lcard:last-child{border-bottom:none}
.list-cards > .lcard:hover,
.lcard:hover{background:var(--panel-2)}
.list-cards > .lcard:active,
.lcard:active{background:var(--line)}
.lcard .label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.lcard .count{color:var(--muted);font-size:12px;flex-shrink:0;font-family:ui-monospace,monospace;font-variant-numeric:tabular-nums}
