/* ═══════════ CSS: tiles ═══════════ */
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;padding:.8rem;box-sizing:border-box}
@media(min-aspect-ratio:16/9){.tile-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-aspect-ratio:9/16){.tile-grid{grid-template-columns:repeat(2,1fr)}}
.tile{aspect-ratio:1;display:flex;flex-direction:column;justify-content:flex-end;padding:1.1rem;text-decoration:none;color:#fff;font-weight:400;font-size:1.5rem;border:2px solid transparent;transition:transform .12s,border-color .12s;overflow:hidden;cursor:pointer;position:relative;box-sizing:border-box}
.tile:active{transform:scale(.95)}
.tile:hover{border-color:rgba(255,255,255,.4)}
.tile-press{animation:tile-press .1s cubic-bezier(.16,1,.3,1) both}
@keyframes tile-press{0%{transform:scale(1)}30%{transform:scale(.92)}100%{transform:scale(.85);opacity:.6}}
.tile.flip-x{animation:tile-flip-x 1.8s cubic-bezier(.15,.85,.35,1.5) forwards}
.tile.flip-y{animation:tile-flip-y 1.8s cubic-bezier(.15,.85,.35,1.5) forwards}
.tile.flip-back-x{animation:tile-flip-x 1.8s cubic-bezier(.15,.85,.35,1.5) reverse forwards}
.tile.flip-back-y{animation:tile-flip-y 1.8s cubic-bezier(.15,.85,.35,1.5) reverse forwards}
@keyframes tile-flip-x{0%{transform:rotateX(0)}100%{transform:rotateX(180deg)}}
@keyframes tile-flip-y{0%{transform:rotateY(0)}100%{transform:rotateY(180deg)}}
.tile-icon{position:absolute;inset:0;font-size:3rem;line-height:1;display:flex;align-items:center;justify-content:center;opacity:.35;pointer-events:none;z-index:2}
.tile-label{font-size:1.8rem;font-weight:400;display:block;line-height:1.05;white-space:nowrap;letter-spacing:-1px;position:absolute;top:1.1rem;left:1.1rem;z-index:3}
.tile-desc{font-size:1.15rem;font-weight:700;opacity:.75;margin-top:.1rem;display:block;overflow:hidden;white-space:nowrap;position:relative;z-index:3;width:100%}
.tile-desc>span{display:inline-block}
.tile-desc.scroll-l>span{animation:marquee-l 3.7s cubic-bezier(.22,.61,.36,1) forwards}
@keyframes marquee-l{0%,5%{transform:translateX(0)}40%,65%{transform:translateX(calc(-1*var(--dx)))}95%,100%{transform:translateX(0)}}
.tile-live{font-size:.75rem;font-weight:400;opacity:.55;margin-top:.25rem;line-height:1.35;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;white-space:normal;position:relative;z-index:3;max-height:2.2rem}
.tile.flipped .tile-label,.tile.flipped .tile-desc,.tile.flipped .tile-icon,.tile.flipped .tile-live{opacity:0;transition:opacity .5s}
.tile-detail{position:absolute;inset:0;padding:1.8rem;display:flex;align-items:center;justify-content:center;font-size:.85rem;line-height:1.3;opacity:0;z-index:10;color:#fff;pointer-events:none;transition:opacity .5s;text-align:center;overflow:hidden;word-break:break-word;border-radius:inherit}
.tile.flipped .tile-detail{opacity:.85}
.t-wp-lime{background:var(--wp-lime)}.t-wp-green{background:var(--wp-green)}
.t-wp-emerald{background:var(--wp-emerald)}.t-wp-teal{background:var(--wp-teal)}
.t-wp-cobalt{background:var(--wp-cobalt)}.t-wp-indigo{background:var(--wp-indigo)}
.t-wp-magenta{background:var(--wp-magenta)}.t-wp-amber{background:var(--wp-amber)}
.t-wp-orange{background:var(--wp-orange)}
.app-list{display:flex;flex-direction:column}
.app-row{display:flex;align-items:center;gap:.8rem;padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.06);text-decoration:none;color:#fff;font-size:.95rem;transition:background .1s}
.app-row:hover{background:rgba(255,255,255,.04)}
.app-row-stack{animation:app-pop .18s cubic-bezier(.16,1,.3,1) both}
@keyframes app-pop{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}
.app-icon{font-size:1.5rem;width:2.2rem;text-align:center;flex-shrink:0}
.app-icon img{width:1.2rem;height:1.2rem;vertical-align:middle}
.app-name{font-weight:600;min-width:5rem;flex-shrink:0}
.app-desc{font-size:.82rem;color:rgba(255,255,255,.45);flex:1}
