:root { --bg: #0c0c0e; --surface: #16161a; --surface-2: #1d1d23; --line: rgba(255,255,255,0.09); --text: #f4f3f0; --dim: rgba(244,243,240,0.66); --faint: rgba(244,243,240,0.42); --accent: #ff6a2b; --accent-ink: #16100c; --radius: 12px; --font: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, "Segoe UI", system-ui, sans-serif; --display: "Barlow Condensed", "Arial Narrow", sans-serif; }
* { margin: 0px; padding: 0px; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--bg); color: var(--text); font-family: var(--font); font-size: 17px; line-height: 1.55; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 4px; }
::selection { background: var(--accent); color: var(--accent-ink); }
button { font-family: inherit; cursor: pointer; }
.wrap { max-width: 1280px; margin: 0px auto; padding: 0px 24px; }
section { padding: 56px 0px 0px; }
.page-top { padding-top: 112px; }
.page-end { padding-bottom: 96px; }
h1, h2, h3, .display { font-family: var(--display); text-wrap: balance; }
.eyebrow { font-size: 14px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-bottom: 10px; }
.page-title { font-size: clamp(44px, 6vw, 76px); font-weight: 700; line-height: 0.98; letter-spacing: 0.005em; text-transform: uppercase; margin-bottom: 18px; }
h2.sec { font-size: clamp(30px, 3.6vw, 44px); font-weight: 700; line-height: 1.02; text-transform: uppercase; margin-bottom: 6px; }
.sec-sub { color: var(--dim); max-width: 62ch; margin-bottom: 26px; text-wrap: pretty; }
.lead { font-size: 19px; color: var(--dim); max-width: 70ch; text-wrap: pretty; }
.prose p { color: var(--dim); max-width: 74ch; margin-bottom: 14px; text-wrap: pretty; }
.prose strong { color: var(--text); }
.top { position: fixed; top: 0px; left: 0px; right: 0px; z-index: 100; background: rgba(10, 11, 14, 0.78); backdrop-filter: blur(18px); border-bottom: 1px solid var(--line); }
.top-inner { max-width: 1280px; margin: 0px auto; padding: 0px 24px; height: 64px; display: flex; align-items: center; gap: 26px; }
.top-nav { display: flex; align-items: center; gap: 24px; }
.top-nav a { font-size: 16px; font-weight: 600; color: var(--dim); transition: color 0.2s; white-space: nowrap; }
.top-nav a:hover { color: var(--text); }
.top-nav a[aria-current="page"] { color: var(--text); box-shadow: inset 0 -2px 0 0 var(--accent); padding-bottom: 4px; }
.ai-search { flex: 1 1 0%; max-width: 420px; margin-left: auto; display: flex; align-items: center; gap: 10px; background: rgba(255, 255, 255, 0.07); border: 1px solid var(--line); border-radius: 999px; padding: 9px 18px; color: var(--faint); font-size: 15px; cursor: pointer; transition: background 0.2s, border-color 0.2s; }
.ai-search:hover { background: rgba(255, 255, 255, 0.11); border-color: rgba(255, 255, 255, 0.18); }
.ai-search .spark { color: var(--accent); flex: 0 0 auto; }
.ai-search .truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.auth { display: flex; align-items: center; gap: 18px; }
.auth a { font-size: 16px; font-weight: 600; color: var(--dim); white-space: nowrap; }
.auth a:hover { color: var(--text); }
.btn-join { background: var(--accent); padding: 10px 20px; border-radius: 999px; transition: filter 0.2s; color: var(--accent-ink) !important; font-weight: 700 !important; }
.btn-join:hover { filter: brightness(1.1); }
.btn-signin { border: 1px solid rgba(255, 255, 255, 0.24); padding: 9px 18px; border-radius: 999px; color: var(--text) !important; transition: border-color 0.2s, background 0.2s; }
.btn-signin:hover { border-color: var(--accent); background: rgba(255, 106, 43, 0.08); }
.avatar { width: 36px; height: 36px; border-radius: 50%; flex: 0 0 auto; background: var(--surface-2); border: 1px solid var(--line); display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; color: var(--accent); }
.when-in { display: none !important; }
body.signed-in .when-in { display: flex !important; }
body.signed-in section.when-in { display: block !important; }
body.signed-in .when-out { display: none !important; }
.wm { display: inline-flex; align-items: center; white-space: nowrap; }
.wm > span { display: none; }
.wm-a, .wm-b, .wm-c { font-family: var(--display); text-transform: uppercase; line-height: 1; }
body[data-wm="a"] .wm-a { display: inline; }
body[data-wm="b"] .wm-b { display: inline; }
body[data-wm="c"] .wm-c { display: inline-flex; }
.wm-a { font-size: 26px; font-weight: 800; letter-spacing: 0.01em; }
.wm-a b { color: var(--accent); font-weight: 800; }
.wm-b { font-size: 26px; font-weight: 800; font-style: italic; letter-spacing: 0.01em; padding-right: 4px; }
.wm-b b { font-weight: 800; color: var(--text); box-shadow: inset 0 -3px 0 0 var(--accent); }
.wm-c { font-size: 19px; font-weight: 600; letter-spacing: 0.22em; border: 1.5px solid var(--text); border-radius: 4px; padding: 5px 10px 5px 13px; align-items: center; gap: 0px; }
.wm-c b { font-weight: 600; color: var(--accent); }
.crumbs { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; font-size: 15px; color: var(--faint); margin-bottom: 22px; }
.crumbs a { color: var(--dim); transition: color 0.2s; }
.crumbs a:hover { color: var(--text); }
.crumbs .sep { opacity: 0.5; }
.crumbs .here { color: var(--text); font-weight: 600; }
.url-chip { display: inline-block; font-size: 13px; color: var(--faint); background: var(--surface); border: 1px solid var(--line); border-radius: 6px; padding: 3px 10px; font-family: ui-monospace, "SF Mono", Menlo, monospace; }
.btn-solid { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--accent); color: var(--accent-ink); font-size: 16px; font-weight: 700; border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; border-radius: 999px; padding: 13px 26px; transition: filter 0.2s; }
.btn-solid:hover { filter: brightness(1.1); }
.btn-ghost { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: transparent; color: var(--text); font-size: 16px; font-weight: 600; border: 1px solid rgba(255, 255, 255, 0.25); border-radius: 999px; padding: 12px 24px; transition: border-color 0.2s, background 0.2s; }
.btn-ghost:hover { border-color: rgba(255, 255, 255, 0.5); background: rgba(255, 255, 255, 0.04); }
.btn-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.wall { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.wall.cols-3 { grid-template-columns: repeat(3, 1fr); }
.wall.cols-6 { grid-template-columns: repeat(6, 1fr); }
.ph { position: relative; display: block; aspect-ratio: 4 / 3; overflow: hidden; border-radius: 10px; background: var(--surface); }
.ph img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.35s; }
a.ph:hover img { transform: scale(1.04); }
.ph .meta { position: absolute; inset: auto 0px 0px; padding: 26px 12px 10px; background: linear-gradient(to top, rgba(8, 8, 10, 0.85), transparent); display: flex; align-items: flex-end; justify-content: space-between; gap: 8px; }
.ph .meta .name { font-size: 14.5px; font-weight: 600; line-height: 1.25; }
.ph .meta .name small { display: block; font-weight: 400; color: var(--dim); font-size: 12.5px; }
.ph .meta .n { font-size: 12.5px; color: var(--dim); white-space: nowrap; }
.ph .badge { position: absolute; top: 10px; left: 10px; font-size: 11.5px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; background: rgba(8, 8, 10, 0.72); border: 1px solid var(--line); color: var(--text); border-radius: 999px; padding: 3px 10px; backdrop-filter: blur(6px); }
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; }
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.stat-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.chip { font-size: 14.5px; color: var(--dim); background: rgba(255, 255, 255, 0.06); border: 1px solid var(--line); border-radius: 999px; padding: 7px 16px; white-space: nowrap; }
.chip b { color: var(--text); font-weight: 700; }
.chip b.hot { color: var(--accent); }
.glance { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.glance div { background: var(--surface); padding: 16px 18px; }
.glance dt { font-size: 12.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--faint); margin-bottom: 4px; }
.glance dd { font-size: 15.5px; color: var(--text); line-height: 1.4; }
.log { width: 100%; border-collapse: collapse; font-size: 15.5px; }
.log th { text-align: left; font-size: 12.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--faint); padding: 10px 14px; border-bottom: 1px solid var(--line); }
.log td { padding: 12px 14px; border-bottom: 1px solid var(--line); vertical-align: top; color: var(--dim); }
.log td:first-child { font-family: var(--display); font-size: 19px; font-weight: 700; color: var(--text); }
.log tr:hover td { background: rgba(255, 255, 255, 0.024); }
.faq { border-top: 1px solid var(--line); }
.faq details { border-bottom: 1px solid var(--line); }
.faq summary { cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 18px 4px; font-size: 18px; font-weight: 600; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 22px; color: var(--accent); flex: 0 0 auto; }
.faq details[open] summary::after { content: "–"; }
.faq .a { padding: 0px 4px 20px; color: var(--dim); max-width: 74ch; text-wrap: pretty; }
.club-unit { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; background: var(--surface); border-top-color: ; border-top-style: ; border-top-width: ; border-right-color: ; border-right-style: ; border-right-width: ; border-bottom-color: ; border-bottom-style: ; border-bottom-width: ; border-image-source: ; border-image-slice: ; border-image-width: ; border-image-outset: ; border-image-repeat: ; border-left-width: medium; border-left-style: none; border-left-color: currentcolor; border-radius: var(--radius); padding: 20px 24px; position: relative; overflow: hidden; }
.club-unit::before { content: ""; position: absolute; left: 0px; top: 0px; bottom: 0px; width: 3px; background: var(--accent); }
.club-logo { width: 56px; height: 56px; border-radius: 12px; flex: 0 0 auto; background: var(--surface-2); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; font-family: var(--display); font-size: 19px; font-weight: 800; color: var(--accent); letter-spacing: 0.02em; }
.club-unit .cu-body { flex: 1 1 0%; min-width: 220px; }
.club-unit .cu-kicker { font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--faint); margin-bottom: 3px; }
.club-unit .cu-name { font-size: 19px; font-weight: 700; line-height: 1.2; }
.club-unit .cu-name a:hover { color: var(--accent); }
.club-unit .cu-counts { font-size: 14.5px; color: var(--dim); margin-top: 2px; }
.club-unit .btn-solid { padding: 10px 22px; font-size: 15px; }
.joined-chip { display: none; align-items: center; gap: 8px; font-size: 15px; font-weight: 700; color: var(--accent); border: 1px solid var(--accent); border-radius: 999px; padding: 10px 20px; }
body.signed-in .join-club { display: none; }
body.signed-in .joined-chip { display: inline-flex; }
.club-card { display: flex; gap: 16px; align-items: flex-start; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 20px; transition: border-color 0.2s, background 0.2s; }
a.club-card:hover { border-color: rgba(255, 255, 255, 0.22); background: var(--surface-2); }
.club-card .cc-name { font-size: 18px; font-weight: 700; line-height: 1.25; }
.club-card .cc-line { font-size: 14.5px; color: var(--dim); margin-top: 3px; }
.club-card .cc-counts { font-size: 13.5px; color: var(--faint); margin-top: 8px; }
.club-card .cc-counts b { color: var(--text); }
.club-card .ext { font-size: 13px; color: var(--accent); }
.ad { margin: 56px auto 0px; max-width: 1280px; padding: 0px 24px; }
.ad .ad-box { height: 112px; border: 1px dashed rgba(255, 255, 255, 0.14); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--faint); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; background: rgba(255, 255, 255, 0.016); }
body.ads-off .ad { display: none; }
.field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 18px; }
.field label { font-size: 14px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--dim); }
.field input, .field select, .field textarea { background: var(--surface-2); border: 1px solid var(--line); border-radius: 10px; color: var(--text); font-family: var(--font); font-size: 17px; padding: 13px 16px; width: 100%; }
.field input::placeholder, .field textarea::placeholder { color: var(--faint); }
.field select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--dim) 50%), linear-gradient(135deg, var(--dim) 50%, transparent 50%); background-position: calc(100% - 21px) 50%, calc(100% - 15px) 50%; background-size: 6px 6px; background-repeat: no-repeat; }
.field .hint { font-size: 13.5px; color: var(--faint); }
.form-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 0px 18px; }
.steps { display: flex; gap: 8px; margin-bottom: 30px; }
.steps .st { flex: 1 1 0%; height: 4px; border-radius: 2px; background: var(--surface-2); }
.steps .st.on { background: var(--accent); }
.step-label { font-size: 13.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--faint); margin-bottom: 8px; }
.dropzone { border: 2px dashed rgba(255, 255, 255, 0.2); border-radius: var(--radius); background: rgba(255, 255, 255, 0.02); padding: 48px 24px; text-align: center; color: var(--dim); transition: border-color 0.2s, background 0.2s; cursor: pointer; }
.dropzone:hover, .dropzone.over { border-color: var(--accent); background: rgba(255, 106, 43, 0.05); }
.dropzone .dz-big { font-family: var(--display); font-size: 26px; font-weight: 700; text-transform: uppercase; color: var(--text); margin-bottom: 6px; }
footer { border-top: 1px solid var(--line); margin-top: 96px; }
.foot-inner { max-width: 1280px; margin: 0px auto; padding: 30px 24px; display: flex; align-items: center; gap: 14px 28px; flex-wrap: wrap; }
.foot-inner .wm { font-size: 16px; }
.foot-inner .wm .wm-a, .foot-inner .wm .wm-b { font-size: 19px; }
.foot-inner .wm .wm-c { font-size: 13px; padding: 3px 7px 3px 9px; }
.foot-links { display: flex; gap: 20px; flex-wrap: wrap; }
.foot-links a { font-size: 14px; color: var(--faint); transition: color 0.2s; }
.foot-links a:hover { color: var(--text); }
.foot-div { width: 1px; height: 14px; align-self: center; background: var(--line); }
.copyright { font-size: 13px; color: var(--faint); margin-left: auto; }
.tweaks { position: fixed; right: 18px; bottom: 18px; z-index: 500; width: 252px; background: rgb(26, 26, 32); border: 1px solid rgba(255, 255, 255, 0.14); border-radius: 14px; padding: 16px; display: none; box-shadow: rgba(0, 0, 0, 0.55) 0px 14px 44px; }
.tweaks.open { display: block; }
.tweaks h4 { font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--dim); display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.tweaks h4 button { background: none; border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; color: var(--faint); font-size: 16px; line-height: 1; }
.tw-row { margin-bottom: 12px; }
.tw-row .tw-label { font-size: 12.5px; font-weight: 600; color: var(--faint); margin-bottom: 6px; }
.tw-seg { display: flex; gap: 6px; }
.tw-seg button { flex: 1 1 0%; background: var(--surface-2); border: 1px solid var(--line); color: var(--dim); font-size: 13px; font-weight: 600; border-radius: 8px; padding: 7px 4px; }
.tw-seg button.on { background: var(--accent); border-color: var(--accent); color: var(--accent-ink); }
.tw-toggle { display: flex; justify-content: space-between; align-items: center; font-size: 14px; color: var(--text); }
.tw-toggle .sw { width: 40px; height: 23px; border-radius: 999px; background: var(--surface-2); border: 1px solid var(--line); position: relative; transition: background 0.2s; }
.tw-toggle .sw::after { content: ""; position: absolute; top: 2px; left: 2px; width: 17px; height: 17px; border-radius: 50%; background: var(--dim); transition: transform 0.2s, background 0.2s; }
.tw-toggle .sw.on { background: var(--accent); border-color: var(--accent); }
.tw-toggle .sw.on::after { transform: translateX(17px); background: var(--accent-ink); }
@media (max-width: 980px) {
  .wall, .wall.cols-6 { grid-template-columns: repeat(3, 1fr); }
  .card-grid { grid-template-columns: 1fr 1fr; }
  .glance { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  /* two-row header: wordmark + search + auth on row 1, nav on row 2 —
     single-row clipped the nav and pushed search/Join off-screen on phones */
  .top-inner { flex-wrap: wrap; gap: 10px; height: auto; padding-top: 9px; padding-bottom: 9px; }
  .wm-a, .wm-b { font-size: 21px; }
  .wm-c { font-size: 15px; }
  .ai-search { flex: 0 0 auto; width: 36px; height: 36px; padding: 0px; justify-content: center; margin-left: auto; }
  .ai-search .truncate { display: none; }
  .top-nav { order: 10; flex: 1 1 100%; gap: 22px; border-top: 1px solid var(--line); padding-top: 8px; }
  .top-nav a { font-size: 15px; }
  .auth { gap: 8px; }
  .auth .hide-m { display: none; }
  .btn-signin { padding: 7px 12px; font-size: 14px; }
  .btn-join { padding: 7px 12px; font-size: 14px; }
  .wall, .wall.cols-3, .wall.cols-6 { grid-template-columns: repeat(2, 1fr); }
  .card-grid { grid-template-columns: 1fr; }
  .form-cols { grid-template-columns: 1fr; }
  .log { font-size: 14px; }
  .log th, .log td { padding: 9px 8px; }
  .copyright { margin-left: 0px; }
  .page-top { padding-top: 124px; }
}
@media (max-width: 420px) {
  .top-inner { gap: 8px; }
  .wm-a, .wm-b { font-size: 18px; }
  .ai-search { width: 32px; height: 32px; }
  .btn-signin, .btn-join { padding: 6px 10px; font-size: 13px; }
}
.livewire { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: rgba(255, 255, 255, 0.016); }
.lw-inner { max-width: 1280px; margin: 0px auto; padding: 0px 24px; height: 56px; display: flex; align-items: center; gap: 18px; }
.lw-label { flex: 0 0 auto; display: flex; align-items: center; gap: 9px; font-size: 12px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--dim); }
.lw-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }
.lw-track { flex: 1 1 0%; overflow: hidden; mask-image: linear-gradient(to right, transparent, rgb(0, 0, 0) 5%, rgb(0, 0, 0) 95%, transparent); }
.lw-feed { display: flex; gap: 44px; width: max-content; }
.lw-item { display: flex; align-items: center; gap: 10px; font-size: 14.5px; color: var(--dim); white-space: nowrap; }
.lw-item b { color: var(--text); font-weight: 600; }
.lw-item .avatar { width: 26px; height: 26px; font-size: 10px; flex: 0 0 auto; }
.lw-item .t { font-size: 13px; color: var(--faint); }
@media (prefers-reduced-motion: no-preference) {
  .lw-feed { animation: 48s linear 0s infinite normal none running lw-scroll; }
  .lw-track:hover .lw-feed { animation-play-state: paused; }
  .lw-dot { animation: 2.2s ease-in-out 0s infinite normal none running lw-pulse; }
}
@keyframes lw-scroll { 
  100% { transform: translateX(-50%); }
}
@keyframes lw-pulse { 
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}
.hero-search { position: relative; }
.sr-panel { display: none; position: absolute; top: calc(100% + 10px); left: 0px; right: 0px; z-index: 6; background: rgba(22, 22, 26, 0.96); border: 1px solid rgba(255, 255, 255, 0.16); border-radius: 16px; padding: 14px; box-shadow: rgba(0, 0, 0, 0.5) 0px 18px 50px; backdrop-filter: blur(14px); }
.sr-panel.on { display: block; }
@media (prefers-reduced-motion: no-preference) {
  .sr-panel.on { animation: 0.22s ease 0s 1 normal none running sr-in; }
}
@keyframes sr-in { 
  0% { opacity: 0; transform: translateY(-6px); }
}
.sr-head { display: flex; justify-content: space-between; gap: 12px; font-size: 13px; color: var(--faint); margin: 2px 4px 10px; }
.sr-head b { color: var(--text); font-weight: 600; }
.sr-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.sr-grid .ph { aspect-ratio: 4 / 3; border-radius: 8px; }
.sr-more { display: block; text-align: center; font-size: 13.5px; font-weight: 600; color: var(--accent); padding: 10px 0px 2px; }
@media (max-width: 720px) {
  .sr-grid { grid-template-columns: repeat(2, 1fr); }
}
.scrub { position: sticky; top: 76px; z-index: 60; display: flex; align-items: center; gap: 20px; background: rgba(12, 12, 14, 0.88); border: 1px solid var(--line); border-radius: 999px; padding: 12px 24px; margin-bottom: 34px; backdrop-filter: blur(14px); }
.scrub .sc-year { font-family: var(--display); font-size: 24px; font-weight: 800; color: var(--accent); min-width: 58px; line-height: 1; }
.sc-track { position: relative; flex: 1 1 0%; height: 34px; cursor: pointer; touch-action: none; }
.sc-line { position: absolute; left: 0px; right: 0px; top: 11px; height: 2px; background: var(--line); border-radius: 1px; }
.sc-fill { position: absolute; left: 0px; top: 11px; height: 2px; background: var(--accent); border-radius: 1px; width: 0px; }
.sc-tick { position: absolute; top: 8px; width: 8px; height: 8px; border-radius: 50%; background: var(--surface-2); border: 1px solid rgba(255, 255, 255, 0.25); transform: translateX(-50%); }
.sc-tick small { position: absolute; top: 14px; left: 50%; transform: translateX(-50%); font-size: 11px; font-weight: 600; color: var(--faint); }
.sc-dot { position: absolute; top: 4px; width: 16px; height: 16px; border-radius: 50%; background: var(--accent); transform: translateX(-50%); box-shadow: rgba(255, 106, 43, 0.22) 0px 0px 0px 4px; pointer-events: none; }
@media (max-width: 720px) {
  .scrub { padding: 10px 18px; top: 64px; }
  .scrub .sc-year { font-size: 20px; min-width: 46px; }
}
@keyframes badge-pop { 
  0% { transform: scale(0) rotate(-14deg); opacity: 0; }
  60% { transform: scale(1.22) rotate(4deg); opacity: 1; }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}
.pop { animation: 0.55s cubic-bezier(0.2, 1.4, 0.4, 1) 0s 1 normal both running badge-pop; }
.hero-badge { position: absolute; z-index: 5; top: 86px; left: 24px; font-family: var(--display); font-size: 15px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; background: var(--accent); color: var(--accent-ink); border-radius: 999px; padding: 7px 16px; box-shadow: rgba(0, 0, 0, 0.45) 0px 6px 20px; }
.joined-chip.show { display: inline-flex; }
.club-unit.demo-joined .join-club { display: none; }
.log tr[data-year] { cursor: pointer; }
.log tr[data-year] td:first-child::after { content: " ›"; color: var(--faint); font-size: 14px; }
.log tr.sel td { background: rgba(255, 106, 43, 0.06); }
.log tr.sel td:first-child { color: var(--accent); }
.wall-filter { display: none; align-items: center; gap: 14px; flex-wrap: wrap; background: var(--surface); border: 1px solid var(--line); border-radius: 999px; padding: 10px 12px 10px 22px; margin-bottom: 18px; font-size: 15px; color: var(--dim); }
.wall-filter.on { display: flex; }
.wall-filter b { color: var(--text); }
.wall-filter button { margin-left: auto; background: var(--surface-2); border: 1px solid var(--line); border-radius: 999px; color: var(--text); font-size: 13.5px; font-weight: 600; padding: 7px 16px; }
.wall-filter button:hover { border-color: rgba(255, 255, 255, 0.35); }
.wall-empty { display: none; border: 2px dashed rgba(255, 255, 255, 0.16); border-radius: var(--radius); padding: 44px 24px; text-align: center; color: var(--dim); }
.wall-empty.on { display: block; }
.wall-empty .we-big { font-family: var(--display); font-size: 28px; font-weight: 700; text-transform: uppercase; color: var(--text); margin-bottom: 6px; }
.mobile-bar { display: none; }
@media (max-width: 720px) {
  body.signed-in .mobile-bar { position: fixed; left: 0px; right: 0px; bottom: 0px; z-index: 130; display: grid; grid-template-columns: 1fr 1fr 1fr; background: rgba(10, 11, 14, 0.92); border-top: 1px solid var(--line); backdrop-filter: blur(16px); padding: 8px 12px calc(8px + env(safe-area-inset-bottom)); }
  body.signed-in { padding-bottom: 84px; }
}
.mobile-bar a { display: flex; flex-direction: column; align-items: center; gap: 3px; font-size: 11.5px; font-weight: 600; color: var(--dim); padding: 5px 4px; min-height: 44px; }
.mobile-bar a svg { flex: 0 0 auto; }
.mobile-bar .mb-up { width: 46px; height: 46px; border-radius: 50%; background: var(--accent); color: var(--accent-ink); display: flex; align-items: center; justify-content: center; margin: -16px 0px 1px; box-shadow: rgba(0, 0, 0, 0.4) 0px 6px 18px; }
.hotspot { position: absolute; z-index: 4; width: 26px; height: 26px; border-radius: 50%; background: rgba(8, 8, 10, 0.55); border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; cursor: pointer; padding: 0px; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
.hotspot::before { content: ""; width: 10px; height: 10px; border-radius: 50%; background: var(--accent); }
@media (prefers-reduced-motion: no-preference) {
  .hotspot::after { content: ""; position: absolute; inset: -5px; border-radius: 50%; border: 1.5px solid var(--accent); opacity: 0.6; animation: 2.4s ease-out 0s infinite normal none running hs-ping; }
}
@keyframes hs-ping { 
  0% { transform: scale(0.6); opacity: 0.7; }
  70% { transform: scale(1.25); opacity: 0; }
  100% { opacity: 0; }
}
.hs-tip { position: absolute; z-index: 5; left: 50%; bottom: calc(100% + 12px); transform: translateX(-50%); width: max-content; max-width: 250px; text-align: left; background: rgba(18, 18, 22, 0.96); border: 1px solid rgba(255, 255, 255, 0.18); border-radius: 10px; padding: 10px 14px; display: none; box-shadow: rgba(0, 0, 0, 0.5) 0px 10px 30px; }
.hotspot.on .hs-tip, .hotspot:hover .hs-tip, .hotspot:focus-visible .hs-tip { display: block; }
.hs-tip .hs-part { font-size: 14.5px; font-weight: 700; color: var(--text); white-space: normal; }
.hs-tip .hs-sub { font-size: 12.5px; color: var(--dim); white-space: normal; }
.btn-follow { display: inline-flex; align-items: center; gap: 8px; background: rgba(20, 20, 24, 0.7); border: 1px solid rgba(255, 255, 255, 0.3); border-radius: 999px; color: var(--text); font-size: 15px; font-weight: 700; padding: 9px 20px; backdrop-filter: blur(8px); transition: border-color 0.2s, background 0.2s; }
.btn-follow:hover { border-color: rgba(255, 255, 255, 0.55); }
.btn-follow .hearted { display: none; }
.btn-follow.on { border-color: var(--accent); color: var(--accent); }
.btn-follow.on .unhearted { display: none; }
.btn-follow.on .hearted { display: inline; }
.mods { display: flex; flex-direction: column; }
.mods .mod { display: flex; align-items: baseline; gap: 10px; padding: 10px 0px; border-bottom: 1px solid var(--line); }
.mods .mod:last-child { border-bottom-width: medium; border-bottom-style: none; border-bottom-color: currentcolor; }
.mods .m-name { font-size: 15px; font-weight: 600; color: var(--text); flex: 1 1 0%; }
.mods .m-when { font-size: 12.5px; color: var(--faint); white-space: nowrap; }
.mods .m-n { font-size: 12.5px; color: var(--accent); white-space: nowrap; }
.topmods { display: flex; flex-direction: column; gap: 12px; max-width: 720px; }
.topmods .tm { display: grid; grid-template-columns: 240px 1fr 90px; gap: 14px; align-items: center; }
.topmods .tm-name { font-size: 15.5px; font-weight: 600; }
.topmods .tm-bar { height: 10px; border-radius: 5px; background: var(--surface-2); overflow: hidden; }
.topmods .tm-bar i { display: block; height: 100%; border-radius: 5px; background: var(--accent); }
.topmods .tm-n { font-size: 14px; color: var(--dim); text-align: right; white-space: nowrap; }
@media (max-width: 720px) {
  .topmods .tm { grid-template-columns: 1fr 80px; }
  .topmods .tm-bar { grid-column: 1 / -1; }
}
.comments { display: flex; flex-direction: column; gap: 18px; max-width: 760px; }
.comment { display: flex; gap: 14px; }
.comment .avatar { flex: 0 0 auto; }
.comment .c-head { font-size: 14px; color: var(--faint); margin-bottom: 2px; }
.comment .c-head b { color: var(--text); font-size: 15px; }
.comment .c-head .op { color: var(--accent); font-weight: 700; font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; margin-left: 6px; }
.comment p.c-body { color: var(--dim); font-size: 15.5px; text-wrap: pretty; }
.comment .c-reply { margin-top: 12px; padding-left: 16px; border-left: 2px solid var(--line); }
.comment-box { display: flex; gap: 14px; align-items: flex-start; }
.comment-box textarea { flex: 1 1 0%; background: var(--surface-2); border: 1px solid var(--line); border-radius: 12px; color: var(--text); font-family: var(--font); font-size: 15.5px; padding: 12px 16px; resize: vertical; min-height: 52px; }
.comment-box textarea::placeholder { color: var(--faint); }
.signin-to-comment { border: 1px dashed rgba(255, 255, 255, 0.18); border-radius: 12px; padding: 16px 20px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; color: var(--dim); font-size: 15px; }
.sig-card .sig-preview { display: flex; align-items: center; gap: 12px; background: rgb(10, 10, 12); border: 1px solid var(--line); border-radius: 8px; padding: 8px 14px 8px 8px; margin: 12px 0px; }
.sig-card .sig-preview img { width: 86px; height: 52px; object-fit: cover; border-radius: 5px; flex: 0 0 auto; }
.sig-card .sig-name { font-family: var(--display); font-size: 17px; font-weight: 800; text-transform: uppercase; line-height: 1.05; }
.sig-card .sig-sub { font-size: 11.5px; color: var(--dim); }
.sig-card .sig-brand { margin-left: auto; font-family: var(--display); font-size: 12px; font-weight: 800; text-transform: uppercase; color: var(--accent); white-space: nowrap; }
.sig-card code { display: block; font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 11.5px; color: var(--faint); background: var(--surface-2); border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; margin-bottom: 12px; overflow-x: auto; white-space: nowrap; }
.follow-feed { display: flex; flex-direction: column; gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.ff-item { display: flex; align-items: center; gap: 16px; background: var(--surface); padding: 14px 18px; transition: background 0.2s; }
.ff-item:hover { background: var(--surface-2); }
.ff-item img { width: 86px; height: 56px; object-fit: cover; border-radius: 8px; flex: 0 0 auto; }
.ff-item .ff-name { font-weight: 700; font-size: 15.5px; }
.ff-item .ff-sub { font-size: 14px; color: var(--dim); }
.ff-item .ff-t { margin-left: auto; font-size: 13px; color: var(--faint); white-space: nowrap; }
.reel { position: fixed; inset: 0px; z-index: 400; background: rgba(5, 5, 7, 0.93); display: flex; align-items: center; justify-content: center; backdrop-filter: blur(10px); }
.reel[hidden] { display: none; }
.reel-stage { position: relative; height: min(86vh, 740px); aspect-ratio: 9 / 16; border-radius: 18px; overflow: hidden; background: rgb(0, 0, 0); cursor: pointer; }
.reel-stage > img { position: absolute; inset: 0px; width: 100%; height: 100%; object-fit: cover; }
.reel-grad { position: absolute; inset: 0px; background: linear-gradient(to top, rgba(5, 5, 7, 0.82) 0%, transparent 36%), linear-gradient(rgba(5, 5, 7, 0.5) 0%, transparent 18%); }
.reel-bars { position: absolute; top: 12px; left: 12px; right: 12px; z-index: 3; display: flex; gap: 5px; }
.reel-bars .rb { flex: 1 1 0%; height: 3px; border-radius: 2px; background: rgba(255, 255, 255, 0.28); overflow: hidden; }
.reel-bars .rb i { display: block; height: 100%; width: 0px; background: rgb(255, 255, 255); }
.reel-meta { position: absolute; left: 18px; right: 18px; bottom: 20px; z-index: 3; }
.reel-year { display: block; font-family: var(--display); font-size: 52px; font-weight: 800; line-height: 1; color: rgb(255, 255, 255); }
.reel-cap { display: block; font-size: 15px; color: rgba(255, 255, 255, 0.85); margin-top: 6px; text-wrap: pretty; }
.reel-x { position: absolute; top: 22px; right: 26px; z-index: 5; background: rgba(255, 255, 255, 0.12); border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; color: rgb(255, 255, 255); font-size: 22px; line-height: 1; width: 42px; height: 42px; border-radius: 50%; }
.reel-end { position: absolute; inset: 0px; z-index: 4; background: rgba(8, 8, 10, 0.86); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; text-align: center; padding: 24px; }
.reel-end[hidden] { display: none; }
.reel-end .re-big { font-family: var(--display); font-size: 44px; font-weight: 800; text-transform: uppercase; line-height: 0.96; }
.reel-end .re-sub { color: var(--dim); font-size: 15px; }
.reel-end .re-url { font-family: ui-monospace, Menlo, monospace; font-size: 12.5px; color: var(--faint); }
.ba { position: relative; aspect-ratio: 16 / 9; border-radius: var(--radius); overflow: hidden; background: var(--surface); }
.ba img { position: absolute; inset: 0px; width: 100%; height: 100%; object-fit: cover; }
.ba .ba-top { position: absolute; inset: 0px; }
.ba .ba-handle { position: absolute; top: 0px; bottom: 0px; width: 2px; background: rgb(255, 255, 255); z-index: 3; box-shadow: rgba(0, 0, 0, 0.6) 0px 0px 12px; pointer-events: none; }
.ba .ba-handle::after { content: "↔"; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 38px; height: 38px; border-radius: 50%; background: rgb(255, 255, 255); color: rgb(17, 17, 17); display: flex; align-items: center; justify-content: center; font-size: 17px; font-weight: 700; }
.ba .ba-label { position: absolute; top: 14px; z-index: 3; font-family: var(--display); font-size: 19px; font-weight: 800; letter-spacing: 0.04em; background: rgba(8, 8, 10, 0.65); border-radius: 999px; padding: 4px 14px; }
.ba .ba-label.l { left: 14px; }
.ba .ba-label.r { right: 14px; }
.ba input[type="range"] { position: absolute; inset: 0px; width: 100%; height: 100%; opacity: 0; cursor: ew-resize; z-index: 4; margin: 0px; }
.snd { display: flex; align-items: center; gap: 12px; padding: 10px 0px; border-bottom: 1px solid var(--line); }
.snd:last-child { border-bottom-width: medium; border-bottom-style: none; border-bottom-color: currentcolor; }
.snd .play { width: 38px; height: 38px; border-radius: 50%; flex: 0 0 auto; background: var(--accent); color: var(--accent-ink); border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; display: flex; align-items: center; justify-content: center; }
.snd .s-name { font-size: 14.5px; font-weight: 600; flex: 1 1 0%; min-width: 0px; }
.snd .s-len { font-size: 12.5px; color: var(--faint); white-space: nowrap; }
.eq { display: flex; gap: 2px; align-items: flex-end; height: 20px; flex: 0 0 auto; }
.eq i { width: 3px; border-radius: 1px; background: var(--accent); opacity: 0.55; }
.eq i:nth-child(1) { height: 30%; }
.eq i:nth-child(2) { height: 70%; }
.eq i:nth-child(3) { height: 45%; }
.eq i:nth-child(4) { height: 90%; }
.eq i:nth-child(5) { height: 55%; }
.eq i:nth-child(6) { height: 75%; }
.eq i:nth-child(7) { height: 35%; }
@media (prefers-reduced-motion: no-preference) {
  .snd.playing .eq i { animation: 0.6s ease-in-out 0s infinite alternate none running eq-b; }
  .snd.playing .eq i:nth-child(2n) { animation-delay: 0.15s; }
  .snd.playing .eq i:nth-child(3n) { animation-delay: 0.3s; }
}
@keyframes eq-b { 
  0% { transform: scaleY(0.4); }
  100% { transform: scaleY(1.15); }
}
.qr-wrap { display: flex; gap: 14px; align-items: center; }
.qr-wrap canvas { width: 92px; height: 92px; border-radius: 8px; background: rgb(255, 255, 255); flex: 0 0 auto; image-rendering: pixelated; }
.spot-add { border: 2px dashed rgba(255, 255, 255, 0.18); border-radius: 10px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; color: var(--dim); font-size: 14px; font-weight: 600; cursor: pointer; aspect-ratio: 4 / 3; background: none; font-family: var(--font); transition: border-color 0.2s, color 0.2s; }
.spot-add:hover { border-color: var(--accent); color: var(--text); }
.swipe { position: fixed; inset: 0px; z-index: 400; background: rgb(0, 0, 0); }
.swipe[hidden] { display: none; }
.sw-rail { height: 100%; overflow-y: auto; scroll-snap-type: y mandatory; scrollbar-width: none; }
.sw-rail::-webkit-scrollbar { display: none; }
.sw-slide { height: 100%; scroll-snap-align: start; scroll-snap-stop: always; position: relative; }
.sw-stage { position: relative; height: 100%; max-width: min(100vw, 62vh); margin: 0px auto; overflow: hidden; }
.sw-stage img { width: 100%; height: 100%; object-fit: cover; }
.sw-grad { position: absolute; inset: 0px; background: linear-gradient(to top, rgba(0, 0, 0, 0.78) 0%, transparent 32%); }
.sw-meta { position: absolute; left: 18px; right: 70px; bottom: 24px; }
.sw-meta .sw-name { font-family: var(--display); font-size: 27px; font-weight: 800; text-transform: uppercase; line-height: 1; }
.sw-meta .sw-sub { font-size: 14px; color: rgba(255, 255, 255, 0.75); margin-top: 4px; }
.sw-meta .sw-link { display: inline-block; margin-top: 10px; font-size: 13.5px; font-weight: 700; color: var(--accent); }
.sw-side { position: absolute; right: 14px; bottom: 28px; display: flex; flex-direction: column; gap: 16px; align-items: center; }
.sw-side button { width: 46px; height: 46px; border-radius: 50%; border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; background: rgba(255, 255, 255, 0.14); color: rgb(255, 255, 255); font-size: 19px; backdrop-filter: blur(6px); }
.sw-side button.on { background: var(--accent); color: var(--accent-ink); }
.sw-side small { display: block; font-size: 10.5px; color: rgba(255, 255, 255, 0.7); margin-top: 3px; }
.swipe .reel-x { position: fixed; }
.sw-hint { position: fixed; top: 24px; left: 50%; transform: translateX(-50%); z-index: 5; font-size: 12.5px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255, 255, 255, 0.6); }
.stories { display: flex; gap: 22px; flex-wrap: wrap; margin-top: 30px; }
.story { display: flex; flex-direction: column; align-items: center; gap: 7px; width: 76px; text-align: center; }
.story .ring { width: 68px; height: 68px; border-radius: 50%; padding: 3px; background: conic-gradient(var(--accent) 0deg, #ffb36b 140deg, var(--accent) 360deg); }
.story .ring.seen { background: var(--surface-2); }
.story .ring img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; border: 3px solid var(--bg); }
.story .s-label { font-size: 12px; color: var(--dim); line-height: 1.25; }
.kit-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px; margin: 14px 0px; }
.kit-grid img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 6px; }
.kit-cap { font-size: 14px; color: var(--dim); background: var(--surface-2); border: 1px solid var(--line); border-radius: 10px; padding: 12px 14px; margin-bottom: 12px; text-wrap: pretty; }
.kit-cap b { color: var(--text); }
.kit-cap .tags { color: var(--accent); }
@media (max-width: 720px) {
  .kit-grid { grid-template-columns: repeat(3, 1fr); }
}
.bow-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.bow { position: relative; aspect-ratio: 9 / 14; border-radius: 16px; overflow: hidden; background: var(--surface); }
.bow img { position: absolute; inset: 0px; width: 100%; height: 100%; object-fit: cover; }
.bow .bow-grad { position: absolute; inset: 0px; background: linear-gradient(to top, rgba(8, 8, 10, 0.85) 0%, transparent 45%), linear-gradient(rgba(8, 8, 10, 0.4) 0%, transparent 20%); }
.bow .bow-kicker { position: absolute; top: 14px; left: 16px; font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255, 255, 255, 0.8); }
.bow .bow-body { position: absolute; left: 16px; right: 16px; bottom: 14px; }
.bow .bow-name { font-family: var(--display); font-size: 30px; font-weight: 800; text-transform: uppercase; line-height: 0.95; }
.bow .bow-sub { font-size: 13px; color: rgba(255, 255, 255, 0.75); margin: 4px 0px 12px; }
.bow .bow-share { font-size: 13.5px; font-weight: 700; background: rgba(255, 255, 255, 0.14); border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; color: rgb(255, 255, 255); border-radius: 999px; padding: 8px 16px; backdrop-filter: blur(6px); }
.bow .bow-share:hover { background: rgba(255, 255, 255, 0.24); }
.bow .bow-wm { position: absolute; top: 12px; right: 14px; font-family: var(--display); font-style: italic; font-size: 14px; font-weight: 800; text-transform: uppercase; color: rgb(255, 255, 255); }
.bow .bow-wm b { box-shadow: inset 0 -2px 0 0 var(--accent); }
@media (max-width: 860px) {
  .bow-grid { grid-template-columns: 1fr; max-width: 360px; }
}
.invites .inv { display: flex; align-items: center; gap: 16px; padding: 14px 0px; border-bottom: 1px solid var(--line); }
.invites .inv:last-child { border-bottom-width: medium; border-bottom-style: none; border-bottom-color: currentcolor; }
.inv .i-badge { width: 42px; height: 42px; border-radius: 50%; flex: 0 0 auto; border: 1.5px dashed rgba(255, 106, 43, 0.6); color: var(--accent); display: flex; align-items: center; justify-content: center; font-family: var(--display); font-size: 18px; font-weight: 800; }
.inv.done .i-badge { border-style: solid; background: var(--accent); color: var(--accent-ink); }
.inv .i-body { flex: 1 1 0%; min-width: 0px; }
.inv .i-name { font-size: 16px; font-weight: 700; }
.inv .i-sub { font-size: 13.5px; color: var(--dim); }
.inv .btn-ghost { padding: 8px 18px; font-size: 14px; flex: 0 0 auto; }
.inv.done .i-name { color: var(--dim); }
.gen-context { display: grid; grid-template-columns: 200px 1fr; gap: 20px; align-items: center; }
.gen-context .gc-img { position: relative; border-radius: 10px; overflow: hidden; aspect-ratio: 4 / 3; }
.gen-context .gc-img img { width: 100%; height: 100%; object-fit: cover; }
.gen-context .gc-img small { position: absolute; left: 8px; bottom: 6px; font-size: 10.5px; color: rgba(255, 255, 255, 0.75); background: rgba(8, 8, 10, 0.6); border-radius: 4px; padding: 2px 7px; }
@media (max-width: 640px) {
  .gen-context { grid-template-columns: 1fr; }
}
.first-photo { border: 2px dashed rgba(255, 106, 43, 0.55); border-radius: var(--radius); background: rgba(255, 106, 43, 0.04); padding: 44px 28px; text-align: center; cursor: pointer; transition: background 0.2s; }
.first-photo:hover { background: rgba(255, 106, 43, 0.08); }
.first-photo .fp-big { font-family: var(--display); font-size: 34px; font-weight: 800; text-transform: uppercase; line-height: 1; margin-bottom: 8px; }
.first-photo p { color: var(--dim); }
.photo-cols { display: grid; grid-template-columns: 1.9fr 1fr; gap: 28px; align-items: start; }
.ph-frame { position: relative; background: rgb(0, 0, 0); border-radius: var(--radius); overflow: hidden; }
.ph-frame img { width: 100%; max-height: 72vh; object-fit: contain; display: block; }
.ph-nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 3; width: 46px; height: 46px; border-radius: 50%; border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; background: rgba(8, 8, 10, 0.65); color: rgb(255, 255, 255); font-size: 20px; backdrop-filter: blur(6px); }
.ph-nav:hover { background: rgba(8, 8, 10, 0.85); }
.ph-nav.prev { left: 14px; }
.ph-nav.next { right: 14px; }
.ph-caption { padding: 18px 4px 0px; }
.ph-caption .pc-text { font-size: 17px; color: var(--text); text-wrap: pretty; }
.ph-caption .pc-meta { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-top: 8px; font-size: 13.5px; color: var(--faint); }
.veh-ctx { display: flex; gap: 14px; align-items: center; }
.veh-ctx img { width: 92px; height: 64px; object-fit: cover; border-radius: 8px; flex: 0 0 auto; }
.veh-ctx .vx-name { font-family: var(--display); font-size: 22px; font-weight: 800; text-transform: uppercase; line-height: 1; }
.veh-ctx .vx-sub { font-size: 13.5px; color: var(--dim); margin-top: 3px; }
@media (max-width: 980px) {
  .photo-cols { grid-template-columns: 1fr; }
}
.edit-banner { position: sticky; top: 76px; z-index: 70; display: flex; align-items: center; gap: 14px; background: rgba(255, 106, 43, 0.1); border: 1px solid rgba(255, 106, 43, 0.45); border-radius: 12px; padding: 12px 18px; margin-bottom: 26px; font-size: 14.5px; color: var(--text); backdrop-filter: blur(10px); }
.edit-banner b { color: var(--accent); }
.pencil { display: inline-flex; align-items: center; gap: 6px; vertical-align: middle; margin-left: 10px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 999px; color: var(--dim); font-size: 12.5px; font-weight: 700; padding: 5px 13px; cursor: pointer; font-family: var(--font); }
.pencil:hover { color: var(--text); border-color: rgba(255, 255, 255, 0.3); }
[contenteditable="true"] { outline: rgba(255, 106, 43, 0.6) dashed 1.5px; outline-offset: 4px; border-radius: 4px; }
.drag-tile { cursor: grab; }
.drag-tile.dragging { opacity: 0.4; }
.drag-tile .dh { position: absolute; top: 8px; right: 8px; z-index: 3; width: 26px; height: 26px; border-radius: 6px; background: rgba(8, 8, 10, 0.7); color: rgba(255, 255, 255, 0.8); display: flex; align-items: center; justify-content: center; font-size: 13px; }
.queue-item { display: flex; gap: 16px; align-items: center; background: var(--surface); border: 1px solid rgba(255, 106, 43, 0.4); border-radius: var(--radius); padding: 14px; margin-bottom: 18px; }
.queue-item img { width: 110px; height: 78px; object-fit: cover; border-radius: 8px; flex: 0 0 auto; }
.queue-item .q-sub { font-size: 13.5px; color: var(--dim); }
.modal { position: fixed; inset: 0px; z-index: 450; background: rgba(5, 5, 7, 0.8); display: flex; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(8px); }
.modal[hidden] { display: none; }
.modal-card { width: 100%; max-width: 460px; background: var(--surface); border: 1px solid rgba(255, 255, 255, 0.16); border-radius: 16px; padding: 26px; box-shadow: rgba(0, 0, 0, 0.6) 0px 24px 70px; }
.modal-card h3 { font-size: 26px; font-weight: 800; text-transform: uppercase; margin-bottom: 16px; }
.link-photos { display: flex; gap: 8px; margin-bottom: 18px; }
.link-photos label { position: relative; cursor: pointer; flex: 1 1 0%; }
.link-photos img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 8px; opacity: 0.55; transition: opacity 0.15s; }
.link-photos input { position: absolute; opacity: 0; }
.link-photos input:checked + img { opacity: 1; outline: 2px solid var(--accent); outline-offset: 1px; }
@media (max-width: 720px) {
  .v-hero { min-height: 56vh; }
  .v-hero .inner, .gen-hero .inner { padding-top: 104px; }
  .v-hero h1 { font-size: clamp(38px, 11vw, 52px); }
  .url-chip { display: none; }
  .reel-stage { height: 100%; max-height: none; width: 100%; aspect-ratio: auto; border-radius: 0px; }
  .reel-x { top: 14px; right: 14px; }
  .glance { grid-template-columns: 1fr; }
  .ph-nav { width: 40px; height: 40px; }
  .ba .ba-label { font-size: 15px; }
  .hist { margin-left: 3px; padding-left: 20px; }
  .hist-entry::before { left: -28px; }
}

