/* linkpage.css — styles for the /l/<id> page (v2 layout)
   Append this to your existing stylesheet (e.g. at the bottom of links.css)
   or save as a new file and add a <link> for it.

   Layout (top to bottom):
   - Big "CONTINUE TO <domain> →" button (full width)
   - Image (left) + title (right)
   - Description (full width)
   - Footer row: pill (left) | stats: age|likes|comments|share (right)
   - Comments thread
*/

/* =========================================================
   LINKPAGE — shareable single-link view
   ========================================================= */

.mn-linkpage {
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  padding: 1.25rem 1rem 2rem;
}

/* Hide the old back link (left in HTML for backward compat) */
.mn-linkpage-back {
  display: none !important;
}

/* The main card — uses the same gradient skin as home .mn-linkcard */
.mn-linkpage-card {
  display: block;
  padding: 1rem;
  border-radius: 18px;
  margin-bottom: 0;
  position: relative;
  overflow: hidden;
  /* The data-color attribute drives --story-solid via the existing
     #home .mn-linkcard[data-color="..."] rules. We re-apply the gradient
     here because we're not inside #home. */
  --story-solid: var(--color-accent-soft);
}

/* Re-apply the home gradient skin for the linkpage card.
   This mirrors the rules in links.css under #home .mn-linkcard. */
.mn-linkpage-card[data-color="play"]           { --story-solid: var(--pill-play); }
.mn-linkpage-card[data-color="breathe"]        { --story-solid: var(--pill-breathe); }
.mn-linkpage-card[data-color="touching_grass"] { --story-solid: var(--pill-touching_grass); }
.mn-linkpage-card[data-color="read"]           { --story-solid: var(--pill-read); }
.mn-linkpage-card[data-color="news"]           { --story-solid: var(--pill-news); }
.mn-linkpage-card[data-color="media"]          { --story-solid: var(--pill-media); }
.mn-linkpage-card[data-color="art"]            { --story-solid: var(--pill-art); }
.mn-linkpage-card[data-color="food"]           { --story-solid: var(--pill-food); }
.mn-linkpage-card[data-color="uplifting"]      { --story-solid: var(--pill-uplifting); }
.mn-linkpage-card[data-color="discover"]       { --story-solid: var(--pill-discover); }
.mn-linkpage-card[data-color="uncover"]        { --story-solid: var(--pill-uncover); }
.mn-linkpage-card[data-color="join_in"]        { --story-solid: var(--pill-join_in); }
.mn-linkpage-card[data-color="stuff"]          { --story-solid: var(--pill-stuff); }
.mn-linkpage-card[data-color="silly"]          { --story-solid: var(--pill-silly); }
.mn-linkpage-card[data-color="music"]          { --story-solid: var(--pill-music); }

/* Dark-mode gradient skin */
body:not([data-mode="light"]) .mn-linkpage-card {
  --story-base: color-mix(in srgb, var(--panel-bg) 22%, #000 78%);
  background:
    radial-gradient(120% 140% at 0% 50%,
      color-mix(in srgb, var(--story-solid) 26%, transparent) 0%,
      transparent 58%),
    radial-gradient(120% 140% at 100% 50%,
      color-mix(in srgb, var(--story-solid) 22%, transparent) 0%,
      transparent 60%),
    linear-gradient(180deg,
      color-mix(in srgb, var(--story-base) 100%, #000 0%) 0%,
      color-mix(in srgb, var(--story-base) 88%, #000 12%) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 0 0 1px color-mix(in srgb, var(--story-solid) 16%, transparent),
    0 18px 50px rgba(0,0,0,0.35);
  color: #fff;
}

/* Light-mode skin */
body[data-mode="light"] .mn-linkpage-card {
  --story-base: color-mix(in srgb, #fff 86%, var(--panel-bg) 14%);
  background:
    radial-gradient(120% 140% at 0% 50%,
      color-mix(in srgb, var(--story-solid) 20%, transparent) 0%,
      transparent 60%),
    radial-gradient(120% 140% at 100% 50%,
      color-mix(in srgb, var(--story-solid) 16%, transparent) 0%,
      transparent 62%),
    linear-gradient(180deg,
      color-mix(in srgb, var(--story-base) 100%, #fff 0%) 0%,
      color-mix(in srgb, var(--story-base) 88%, #fff 12%) 100%);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--story-solid) 16%, rgba(0,0,0,0.10)),
    0 16px 40px rgba(0,0,0,0.10);
  color: #14131a;
}

/* ----- Top "CONTINUE TO <domain>" button ----- */

.mn-linkpage-continue {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  width: 100%;
  padding: 0.95rem 1.25rem;
  margin-bottom: 1.1rem;
  border-radius: 14px;
  font-family: var(--font-header);
  font-weight: 900;
  font-size: 1rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  color: inherit;
  background: color-mix(in srgb, var(--story-solid) 22%, transparent);
  border: 1px solid color-mix(in srgb, var(--story-solid) 40%, transparent);
  transition: background 160ms ease, box-shadow 160ms ease, transform 80ms ease;
}

.mn-linkpage-continue:hover,
.mn-linkpage-continue:focus-visible {
  background: color-mix(in srgb, var(--story-solid) 38%, transparent);
  outline: none;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--story-solid) 50%, transparent);
}

.mn-linkpage-continue:active {
  transform: translateY(1px);
}

.mn-linkpage-continue i {
  font-size: 0.9rem;
}

/* ----- Image + title row ----- */

.mn-linkpage-card-inner {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 1.1rem;
  align-items: start;
  margin-bottom: 0.85rem;
}

/* Tablet / narrow desktop: image becomes 1:1, smaller title, still side-by-side */
@media (max-width: 800px) and (min-width: 601px) {
  .mn-linkpage-card-inner {
    grid-template-columns: 180px 1fr;
    gap: 0.95rem;
  }

  .mn-linkpage-thumb {
    aspect-ratio: 1 / 1;
  }

  .mn-linkpage-title,
  .mn-linkpage-title a {
    font-size: 1.25rem;
    line-height: 1.22;
  }
}

/* Mobile: stack image above title, image full-width 16:9 */
@media (max-width: 600px) {
  .mn-linkpage-card-inner {
    grid-template-columns: 1fr;
    gap: 0.85rem;
  }

  .mn-linkpage-thumb {
    max-width: none;
    width: 100%;
    margin: 0;
    /* base 16:9 inherits, no need to redeclare */
  }

  .mn-linkpage-titleblock {
    padding-top: 0;
  }

  .mn-linkpage-title,
  .mn-linkpage-title a {
    font-size: 1.25rem;
    line-height: 1.22;
    text-align: left;
  }
}

.mn-linkpage-thumb {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 12px;
  overflow: hidden;
  background: color-mix(in srgb, var(--panel-bg) 70%, transparent);
  position: relative;
}

.mn-linkpage-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mn-linkpage-titleblock {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  padding-top: 0.1rem;
}

.mn-linkpage-title,
.mn-linkpage-title a {
  font-family: var(--font-header);
  font-weight: 900;
  font-size: 1.55rem;
  line-height: 1.18;
  letter-spacing: -0.01em;
  margin: 0;
  text-align: left;
  display: block;
  color: inherit;
  text-decoration: none;
}

.mn-linkpage-title a:hover,
.mn-linkpage-title a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 3px;
  outline: none;
}

/* ----- Description (full width below image/title row) ----- */

.mn-linkpage-desc {
  margin: 0 0 0.95rem;
  opacity: 0.9;
  line-height: 1.5;
  font-size: 1rem;
}

@media (max-width: 600px) {
  .mn-linkpage-desc {
    font-size: 0.95rem;
  }
}

/* ----- Footer row: pill (left) + stats (right) ----- */

.mn-linkpage-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 0.4rem;
}

/* Stats bar (mirrors home feed .mn-linkcard-bar style) */
.mn-linkpage-statsbar {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

.mn-linkpage-age {
  opacity: 0.85;
}

.mn-linkpage-statsep {
  opacity: 0.35;
}

.mn-linkpage-likebtn,
.mn-linkpage-sharebtn,
.mn-linkpage-stat-readonly {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
  background: transparent;
  border: 0;
  padding: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  opacity: 0.85;
  cursor: pointer;
  transition: opacity 140ms ease;
}

.mn-linkpage-likebtn:hover,
.mn-linkpage-likebtn:focus-visible,
.mn-linkpage-sharebtn:hover,
.mn-linkpage-sharebtn:focus-visible {
  opacity: 1;
  outline: none;
}

.mn-linkpage-likebtn:hover i {
  color: #ff6b8a;
}

.mn-linkpage-sharebtn i {
  font-size: 0.85rem;
}

.mn-linkpage-stat-readonly {
  cursor: default;
}

/* ----- Comments below the card ----- */

.mn-linkpage-comments {
  margin-top: 1rem;
  padding: 0 0.25rem;
}

.mn-linkpage-comments .mn-comments-divider {
  margin: 0 0 1rem;
  height: 1px;
  background: color-mix(in srgb, currentColor 14%, transparent);
}

.mn-linkpage-comments .mn-comments-list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 1rem;
}

.mn-linkpage-comments .mn-comments-empty {
  padding: 0.5rem 0 1rem;
}

.mn-linkpage-comments .mn-comments-compose {
  margin-top: 0.5rem;
}

.mn-comments-loginprompt {
  padding: 0.75rem;
  border-radius: 12px;
  background: color-mix(in srgb, var(--panel-bg) 55%, transparent);
  border: 1px solid color-mix(in srgb, var(--panel-border) 60%, transparent);
  font-size: 0.9rem;
  opacity: 0.9;
  text-align: center;
}

.mn-comments-loginprompt a {
  color: inherit;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ----- Not-found / error states ----- */

.mn-linkpage-notfound,
.mn-linkpage-error {
  padding: 3rem 1rem;
  text-align: center;
}

.mn-linkpage-notfound-title {
  font-family: var(--font-header);
  font-weight: 900;
  font-size: 1.4rem;
  margin: 0 0 0.6rem;
}

.mn-linkpage-notfound-body {
  opacity: 0.8;
  margin: 0 0 1.2rem;
}

.mn-linkpage-loading {
  padding: 3rem 1rem;
  text-align: center;
  opacity: 0.6;
}
