/* Page layout, main layout, section head, sticky toolbar, feed tabs, grid */

/* ---------- LAYOUT ---------- */
.shell{max-width:1440px;margin:0 auto;padding:0 28px}


/* ---------- MAIN LAYOUT ---------- */
.main-section{
  position:relative;
}
.main-section > .trend-sec-num{
  position:absolute;top:28px;left:24px;z-index:2;
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.25em;font-weight:600;
  color:var(--ink-dim);opacity:.45;
}
.main-section > .trend-sec-num b{color:var(--accent);font-weight:700}

.main{
  display:grid;grid-template-columns:300px 1fr;gap:40px;
  padding:36px 0 64px;
}
.main > aside{order:1}
.main > div:not(aside){order:2}
@media (max-width:960px){
  .main{grid-template-columns:1fr}
  .main > aside{order:2}
  .main > div:not(aside){order:1}
}


/* ---------- SECTION HEAD ---------- */
/* ═══ STICKY TOOLBAR (homepage) — Pinterest/Behance style ═══ */
.sticky-toolbar{
  position:sticky;
  top:60px; /* header height (~62px) */
  z-index:20;
  margin:-8px -12px 14px; /* negative margin so blur hides content behind edges */
  padding:10px 12px;
  background:rgba(11,11,10,.72);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:border-bottom-color .2s, background .2s;
}
/* When sticky is "stuck" (any scroll), add bottom border for separation */
.sticky-toolbar.is-stuck{
  border-bottom-color:var(--line);
  background:rgba(11,11,10,.85);
}

.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px;
}
.sticky-toolbar .sec-head{margin-bottom:0}
.sec-head-title{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;min-width:0}
.sec-head h2{
  font-family:"Fraunces",serif;font-weight:400;font-size:36px;letter-spacing:-0.02em;margin:0;
  transition:font-size .2s;
}
.sec-head h2 em{font-style:italic;color:var(--accent);font-weight:300}

/* When scrolled/stuck → compact single-line layout.
   feed-tabs is relocated by JS into the sec-head, between title and tools,
   so everything fits on ONE line: [title] [tabs] [tools]
   All direct children are forced to the SAME height via align-items + consistent padding */
.sticky-toolbar.is-stuck{
  padding:10px 12px;
  margin:0 -12px 14px;
}
.sticky-toolbar.is-stuck .sec-head{
  align-items:center;margin-bottom:0;flex-wrap:nowrap;gap:16px;
}
.sticky-toolbar.is-stuck .sec-head h2{
  font-size:20px;white-space:nowrap;flex-shrink:0;
  line-height:1;margin:0;
}
.sticky-toolbar.is-stuck .results-count{display:none}
.sticky-toolbar.is-stuck .sec-head-title{flex-wrap:nowrap;flex-shrink:0;display:flex;align-items:center;height:34px}

/* Tools row at 34px height */
.sticky-toolbar.is-stuck .tools{gap:6px;align-items:center;height:34px}
.sticky-toolbar.is-stuck .tools .count-select{height:34px;display:flex;align-items:center}
.sticky-toolbar.is-stuck .tools .sort,
.sticky-toolbar.is-stuck .tools .count-btn{
  height:34px;padding:0 12px;font-size:12px;
  display:inline-flex;align-items:center;gap:6px;line-height:1;
}
.sticky-toolbar.is-stuck .tools .view-toggle{
  height:34px;padding:3px;gap:1px;display:flex;align-items:center;box-sizing:border-box;
}
.sticky-toolbar.is-stuck .tools .view-toggle button{
  height:100%;padding:0 8px;display:inline-flex;align-items:center;
}
.sticky-toolbar.is-stuck .tools .view-toggle svg{width:13px;height:13px}

/* feed-tabs inside sec-head when stuck — same 34px height */
.sticky-toolbar.is-stuck .sec-head > .feed-tabs{
  margin-top:0;border-bottom:0;height:34px;
  flex:1;min-width:0;overflow-x:auto;scrollbar-width:none;
  justify-content:flex-start;align-items:center;
}
.sticky-toolbar.is-stuck .sec-head > .feed-tabs::-webkit-scrollbar{display:none}
.sticky-toolbar.is-stuck .sec-head > .feed-tabs .feed-tab{
  height:34px;padding:0 12px;font-size:12.5px;
  border-bottom:0;border-radius:6px;
  margin-bottom:0;display:inline-flex;align-items:center;
}
.sticky-toolbar.is-stuck .sec-head > .feed-tabs .feed-tab.active{
  background:rgba(212,255,62,.1);
  border-bottom:0;
}
.sticky-toolbar.is-stuck .sec-head > .feed-tabs .feed-tab svg{width:12px;height:12px}

/* Feed tabs (For you / Latest / Trending / Popular) */
.feed-tabs{
  display:flex;gap:4px;margin-top:18px;
  border-bottom:1px solid var(--line);
  overflow-x:auto;scrollbar-width:none;
}
.feed-tabs::-webkit-scrollbar{display:none}
.feed-tab{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 16px 14px;
  background:transparent;border:0;cursor:pointer;
  color:var(--ink-dim);font-family:"Geist",sans-serif;font-size:14px;font-weight:500;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  white-space:nowrap;transition:color .15s, border-color .15s;
}
.feed-tab svg{width:14px;height:14px;flex-shrink:0}
.feed-tab:hover{color:var(--ink)}
.feed-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.feed-tab[data-auth="member"]{display:none} /* hidden by default — shown only when member/editor/chief/admin */
body[data-role="member"] .feed-tab[data-auth="member"],
body[data-role="editor"] .feed-tab[data-auth="member"],
body[data-role="chief"] .feed-tab[data-auth="member"],
body[data-role="admin"] .feed-tab[data-auth="member"]{display:inline-flex}

/* When stuck, tabs become more compact */

/* Empty state for For you feed */
.foryou-empty{
  grid-column:1/-1;
  padding:48px 20px;text-align:center;
  background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius-lg);
}
.foryou-empty svg{width:44px;height:44px;color:var(--accent);margin-bottom:14px;opacity:.6}
.foryou-empty h3{font-family:"Fraunces",serif;font-weight:400;font-size:22px;margin:0 0 8px;color:var(--ink)}
.foryou-empty h3 em{font-style:italic;color:var(--accent);font-weight:300}
.foryou-empty p{margin:0 auto;max-width:420px;color:var(--ink-soft);font-size:14px;line-height:1.5}

/* Results count badge */
.results-count{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.1em;
  color:var(--ink-dim);padding:3px 8px;
  border-radius:4px;background:var(--bg-2);border:1px solid var(--line);
  white-space:nowrap;
}
.results-count b{color:var(--accent);font-weight:700}

.sec-head .tools{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.view-toggle{
  display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--surface);
  padding:3px;gap:2px;
}
.view-toggle button{
  padding:7px 9px;color:var(--ink-dim);
  display:grid;place-items:center;
  border-radius:7px;
  transition:background .15s, color .15s;
}
.view-toggle button:hover{color:var(--ink)}
.view-toggle button.active{background:var(--surface-2);color:var(--ink)}
.view-toggle svg{width:15px;height:15px}

.sort{
  display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid var(--line);
  border-radius:10px;background:var(--surface);color:var(--ink-soft);font-size:13px;
  cursor:pointer;transition:border-color .15s, color .15s;
}
.sort:hover{border-color:var(--line-strong);color:var(--ink)}
.sort svg{width:13px;height:13px}

.count-select{
  position:relative;
}
.count-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 12px;border:1px solid var(--line);border-radius:10px;
  background:var(--surface);color:var(--ink-soft);font-size:13px;
  cursor:pointer;transition:border-color .15s, color .15s;
  font-family:inherit;
}
.count-btn:hover{border-color:var(--line-strong);color:var(--ink)}
.count-btn svg{width:13px;height:13px}
.count-btn b{color:var(--ink);font-family:"JetBrains Mono",monospace;font-weight:700;font-size:12.5px}

.count-menu{
  position:absolute;top:calc(100% + 6px);right:0;z-index:40;
  background:var(--surface);border:1px solid var(--line-strong);border-radius:10px;
  padding:4px;min-width:140px;
  box-shadow:0 12px 32px -6px rgba(0,0,0,.6);
  opacity:0;transform:translateY(-6px);pointer-events:none;
  transition:opacity .15s, transform .15s;
}
.count-menu.open{opacity:1;transform:translateY(0);pointer-events:auto}
.count-menu button{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:8px 12px;border-radius:6px;
  font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;
  color:var(--ink-soft);text-align:left;
}
.count-menu button:hover{background:var(--bg-2);color:var(--ink)}
.count-menu button.on{background:var(--bg-2);color:var(--accent);font-weight:700}
.count-menu button.on::after{content:"✓";color:var(--accent)}
.count-menu .label{
  padding:6px 12px 4px;font-family:"JetBrains Mono",monospace;font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);
}


/* ---------- GRID ---------- */
.grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px 20px;
}

