/* public/styles/apps.css — apps index + detail (Cyan Glass). All rules scoped to page roots. */

/* ============ INDEX ============ */
.apps-index { padding: 8px 0 40px; }
.apps-index .apps-head { padding: 34px 0 30px; }
.apps-index .apps-head .eyebrow { margin-bottom: 18px; }
.apps-index .apps-head h1 { font-family: var(--font-sans); font-weight: 800; letter-spacing: -.035em; font-size: clamp(36px, 5vw, 62px); line-height: 1; }
.apps-index .apps-head p { color: var(--ink-soft); font-size: 17px; max-width: 54ch; margin-top: 16px; text-wrap: pretty; }
.apps-index .stat { display: flex; gap: 26px; margin-top: 24px; font-family: var(--font-mono); font-size: 12.5px; color: var(--ink-faint); flex-wrap: wrap; }
.apps-index .stat b { color: var(--accent); font-weight: 600; }

.apps-index .featured { border-radius: var(--radius-lg); padding: 38px; margin-bottom: 46px; position: relative; overflow: hidden; }
.apps-index .featured::before { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 130% at 90% -10%, var(--accent-soft), transparent 55%); pointer-events: none; }
.apps-index .featured .ftag { position: absolute; top: 24px; right: 28px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 32%, transparent); background: var(--accent-soft); padding: 5px 12px; border-radius: 999px; }
.apps-index .featured-grid { display: grid; grid-template-columns: 1fr auto; gap: 40px; align-items: center; position: relative; }
.apps-index .fhead { display: flex; align-items: center; gap: 20px; margin-bottom: 22px; }
.apps-index .fhead .ic { width: 92px; height: 92px; border-radius: 22px; box-shadow: 0 14px 34px -12px rgba(8,40,60,.5); flex-shrink: 0; object-fit: cover; }
.apps-index .fhead .ic.emoji { display: grid; place-items: center; font-size: 42px; background: linear-gradient(150deg, var(--accent), var(--accent-bright)); color: var(--accent-ink); }
.apps-index .fhead .nm { font-family: var(--font-sans); font-weight: 800; letter-spacing: -.03em; font-size: 34px; line-height: 1; color: var(--ink); }
.apps-index .fhead .cat-line { display: flex; align-items: center; gap: 10px; margin-top: 10px; font-family: var(--font-mono); font-size: 12.5px; color: var(--ink-faint); flex-wrap: wrap; }
.apps-index .fhead .stars { color: var(--accent); letter-spacing: 2px; }
.apps-index .featured .ftagline { font-size: 19px; color: var(--ink); font-weight: 500; margin-bottom: 14px; letter-spacing: -.01em; }
.apps-index .featured .fdesc { color: var(--ink-soft); font-size: 15.5px; max-width: 52ch; margin-bottom: 26px; line-height: 1.6; }
.apps-index .fcta { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.apps-index .shots { display: flex; gap: 14px; }
.apps-index .shots .shot { width: 152px; height: 330px; border-radius: 26px; border: 6px solid color-mix(in srgb, var(--ink) 78%, #000); object-fit: cover; box-shadow: 0 22px 50px -22px rgba(8,40,60,.5); background: var(--bg2); }
.apps-index .shots .shot:nth-child(2) { margin-top: 24px; opacity: .9; }

.apps-index .grid-head { font-family: var(--font-mono); font-size: 12.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
.apps-index .grid-head::before { content: ""; width: 26px; height: 1px; background: var(--line-strong); }
.apps-index .app-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 30px; }
.apps-index .acard { position: relative; border-radius: var(--radius); padding: 24px; display: flex; flex-direction: column; transition: .22s var(--ease); color: inherit; }
.apps-index .acard:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg), inset 0 1.5px 0 var(--rim); }
.apps-index .acard .card-overlay { position: absolute; inset: 0; z-index: 1; border-radius: var(--radius); }
.apps-index .acard .top { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; }
.apps-index .acard .ic { width: 64px; height: 64px; border-radius: 16px; box-shadow: 0 8px 20px -8px rgba(8,40,60,.4); flex-shrink: 0; object-fit: cover; }
.apps-index .acard .ic.emoji { display: grid; place-items: center; font-size: 30px; background: linear-gradient(150deg, var(--accent), var(--accent-bright)); color: var(--accent-ink); }
.apps-index .acard .nm { font-family: var(--font-sans); font-weight: 700; font-size: 19px; letter-spacing: -.02em; display: flex; align-items: center; gap: 10px; color: var(--ink); }
.apps-index .acard .ct { font-family: var(--font-mono); font-size: 11.5px; color: var(--ink-faint); margin-top: 4px; }
.apps-index .acard .tg { color: var(--ink-soft); font-size: 14.5px; line-height: 1.55; flex: 1; margin-bottom: 18px; text-wrap: pretty; }
.apps-index .acard .bot { display: flex; align-items: center; justify-content: space-between; gap: 12px; position: relative; z-index: 2; }
.apps-index .acard .stars { color: var(--accent); font-size: 13px; letter-spacing: 1.5px; }
.apps-index .wip { font-family: var(--font-mono); font-size: 11px; color: var(--term-amber); border: 1px solid color-mix(in srgb, var(--term-amber) 40%, transparent); background: color-mix(in srgb, var(--term-amber) 12%, transparent); padding: 3px 9px; border-radius: 999px; white-space: nowrap; }

@media (max-width: 860px) {
  .apps-index .featured-grid { grid-template-columns: 1fr; }
  .apps-index .shots { justify-content: flex-start; }
  .apps-index .app-grid { grid-template-columns: 1fr; }
}
@media (max-width: 520px) { .apps-index .shots .shot:nth-child(2) { display: none; } }

/* ============ DETAIL ============ */
.app-detail { max-width: 1000px; margin: 0 auto; padding: 0 0 40px; }
.app-detail .backrow { padding: 24px 0 0; }
.app-detail .backlink { font-family: var(--font-mono); font-size: 13px; color: var(--ink-soft); display: inline-flex; gap: 8px; align-items: center; transition: .18s var(--ease); }
.app-detail .backlink:hover { color: var(--accent); gap: 11px; }

.app-detail .app-hero { display: flex; align-items: center; gap: 26px; padding: 30px 0; border-bottom: 1px solid var(--line); flex-wrap: wrap; }
.app-detail .app-hero .ic { width: 118px; height: 118px; border-radius: 27px; box-shadow: 0 18px 40px -14px rgba(8,40,60,.5); flex-shrink: 0; object-fit: cover; }
.app-detail .app-hero .ic.emoji { display: grid; place-items: center; font-size: 54px; background: linear-gradient(150deg, var(--accent), var(--accent-bright)); color: var(--accent-ink); }
.app-detail .app-hero .meta { flex: 1; min-width: 240px; }
.app-detail .app-hero h1 { font-family: var(--font-sans); font-weight: 800; letter-spacing: -.03em; font-size: clamp(30px, 3.6vw, 42px); line-height: 1.02; color: var(--ink); }
.app-detail .app-hero .sub { color: var(--ink-soft); font-size: 17px; margin-top: 7px; }
.app-detail .app-hero .dev { font-family: var(--font-mono); font-size: 12.5px; color: var(--accent); margin-top: 12px; }
.app-detail .app-hero .actions { display: flex; align-items: center; gap: 18px; margin-top: 20px; flex-wrap: wrap; }
.app-detail .app-hero .price { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; font-family: var(--font-mono); font-size: 11px; color: var(--ink-faint); }

.app-detail .facts { display: grid; grid-template-columns: repeat(4, 1fr); border-bottom: 1px solid var(--line); margin-bottom: 8px; }
.app-detail .fact { padding: 22px 18px; text-align: center; border-right: 1px solid var(--line); }
.app-detail .fact:last-child { border-right: 0; }
.app-detail .fact .lbl { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 8px; }
.app-detail .fact .val { font-family: var(--font-sans); font-weight: 700; font-size: 20px; letter-spacing: -.02em; color: var(--ink); }
.app-detail .fact .val small { font-size: 12px; color: var(--ink-faint); font-weight: 500; display: block; margin-top: 3px; font-family: var(--font-mono); }
.app-detail .fact .stars { color: var(--accent); font-size: 13px; letter-spacing: 1px; display: block; margin-top: 4px; }

.app-detail .app-sec { padding: 40px 0; border-bottom: 1px solid var(--line); }
.app-detail .app-sec:last-of-type { border-bottom: 0; }
.app-detail .app-sec h2 { font-family: var(--font-sans); font-weight: 700; letter-spacing: -.02em; font-size: 23px; margin-bottom: 18px; color: var(--ink); }

/* Novedades (release notes) */
.app-detail .seerow { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.app-detail .seerow h2 { margin-bottom: 0; }
.app-detail .seerow .ver { font-family: var(--font-mono); font-size: 12.5px; color: var(--ink-faint); white-space: nowrap; }
.app-detail .notes { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 9px; max-width: 64ch; }
.app-detail .notes li { padding-left: 24px; position: relative; color: var(--ink); font-size: 15.5px; line-height: 1.6; }
.app-detail .notes li::before { content: ""; position: absolute; left: 4px; top: 9px; width: 7px; height: 7px; border-radius: 2px; background: var(--accent); }

.app-detail .shots-rail { display: flex; gap: 16px; overflow-x: auto; padding: 4px 0 14px; scroll-snap-type: x mandatory; }
.app-detail .shots-rail::-webkit-scrollbar { height: 8px; }
.app-detail .shots-rail::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 8px; }
.app-detail .shots-rail .shot { flex: 0 0 auto; width: 188px; height: 406px; border-radius: 30px; border: 7px solid color-mix(in srgb, var(--ink) 80%, #000); scroll-snap-align: start; object-fit: cover; box-shadow: 0 20px 44px -22px rgba(8,40,60,.45); background: var(--bg2); }

.app-detail .desc { font-size: 16.5px; line-height: 1.75; color: var(--ink); max-width: 64ch; }
.app-detail .desc :global(p) { margin-bottom: 18px; }
.app-detail .desc :global(p:last-child) { margin-bottom: 0; }
.app-detail .desc :global(strong) { font-weight: 650; color: var(--ink); }

.app-detail .feats { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 9px; max-width: 64ch; }
.app-detail .feats li { padding-left: 24px; position: relative; color: var(--ink); font-size: 15.5px; line-height: 1.6; }
.app-detail .feats li::before { content: ""; position: absolute; left: 4px; top: 9px; width: 7px; height: 7px; border-radius: 2px; background: var(--accent); }

.app-detail .info-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 40px; max-width: 680px; }
.app-detail .info-row { display: flex; justify-content: space-between; gap: 14px; padding: 13px 0; border-bottom: 1px solid var(--line); font-size: 14.5px; }
.app-detail .info-row .k { color: var(--ink-faint); }
.app-detail .info-row .v { color: var(--ink); font-weight: 500; text-align: right; }
.app-detail .app-links { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.app-detail .app-link { display: inline-flex; align-items: center; gap: 10px; font-size: 14.5px; font-weight: 500; padding: 13px 20px; border-radius: 12px; border: 1px solid var(--line); background: var(--glass-strong); box-shadow: inset 0 1.5px 0 var(--rim); color: var(--ink); transition: .2s var(--ease); }
.app-detail .app-link:hover { border-color: color-mix(in srgb, var(--accent) 42%, transparent); color: var(--accent); transform: translateY(-2px); }
.app-detail .app-link .i { color: var(--accent); font-size: 16px; }
.app-detail .app-link .ar { margin-left: 2px; color: var(--ink-faint); }
.app-detail .app-link:hover .ar { color: var(--accent); }

.app-detail .rate-grid { display: grid; grid-template-columns: auto 1fr; gap: 36px; align-items: center; max-width: 560px; }
.app-detail .rate-big { text-align: center; }
.app-detail .rate-big .n { font-family: var(--font-sans); font-weight: 800; font-size: 56px; letter-spacing: -.03em; line-height: 1; color: var(--ink); }
.app-detail .rate-big .of { font-family: var(--font-mono); font-size: 12px; color: var(--ink-faint); margin-top: 4px; }
.app-detail .rate-big .st { color: var(--accent); letter-spacing: 2px; margin-top: 8px; }
.app-detail .bars { display: flex; flex-direction: column; gap: 7px; }
.app-detail .bar-row { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 11px; color: var(--ink-faint); }
.app-detail .bar-row .t { width: 14px; text-align: right; }
.app-detail .bar-row .track { flex: 1; height: 7px; border-radius: 999px; background: var(--line); overflow: hidden; }
.app-detail .bar-row .fill { height: 100%; background: var(--accent); border-radius: 999px; }

@media (max-width: 720px) {
  .app-detail .facts { grid-template-columns: repeat(2, 1fr); }
  .app-detail .fact:nth-child(2) { border-right: 0; }
  .app-detail .info-grid { grid-template-columns: 1fr; }
  .app-detail .rate-grid { grid-template-columns: 1fr; gap: 20px; }
}
