.catalog.section{padding-top:48px}.tile-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.work-tile{min-width:0}.tile-link{position:relative;display:block;overflow:hidden;aspect-ratio:5/7;border:1px solid var(--line);border-radius:18px;background:var(--panel)}.tile-link::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(7,7,12,.35) 56%,rgba(7,7,12,.98) 100%)}.tile-link img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease,filter .35s ease}.work-tile:hover .tile-link{border-color:#615777}.work-tile:hover .tile-link img{transform:scale(1.055);filter:saturate(1.08)}.tile-code{position:absolute;z-index:2;top:12px;left:12px;display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid rgba(255,255,255,.3);border-radius:10px;background:rgba(7,7,12,.94);color:#fff;box-shadow:0 3px 12px rgba(0,0,0,.45);backdrop-filter:blur(10px);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 1px 2px #000}.tile-code::before{content:"\54C1\756A";color:#d2ced9;font-size:8px;font-weight:600;letter-spacing:.08em}.tile-overlay{position:absolute;z-index:2;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:14px}.tile-rating{align-self:flex-end;display:flex;align-items:baseline;gap:4px;padding:7px 10px;border:1px solid rgba(255,255,255,.3);border-radius:10px;background:rgba(7,7,12,.94);color:#fff;box-shadow:0 3px 12px rgba(0,0,0,.45);backdrop-filter:blur(10px);text-shadow:0 1px 2px #000}.tile-rating span{margin-right:2px;color:#d2ced9;font-size:9px;font-weight:600}.tile-rating strong{color:#fff;font-size:18px;line-height:1}.tile-rating small{color:#d2ced9;font-size:9px}.tile-copy p{margin:0 0 4px;color:#c8c3cf;font-size:9px;letter-spacing:.05em}.tile-copy h3{margin:0;font-size:clamp(17px,1.7vw,24px);line-height:1.35}.tile-more{display:flex;max-height:0;justify-content:space-between;overflow:hidden;margin-top:0;border-top:1px solid transparent;color:#ded9e5;font-size:10px;font-weight:700;opacity:0;transition:.3s}.tile-more b{color:var(--accent2)}.work-tile:hover .tile-more{max-height:40px;margin-top:12px;padding-top:10px;border-color:rgba(255,255,255,.14);opacity:1}@media(max-width:900px){.tile-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:620px){.catalog.section{padding-top:32px}.tile-grid{width:calc(100vw - 40px);grid-template-columns:repeat(2,minmax(0,calc((100vw - 50px)/2)));gap:10px}.work-tile,.tile-link{width:100%;min-width:0}.tile-link{border-radius:14px}.tile-overlay{padding:10px}.tile-code{top:10px;right:92px;left:10px;gap:4px;overflow:hidden;height:30px;padding:0 7px;border-right:0;border-radius:9px 0 0 9px;font-size:9px;text-overflow:ellipsis;white-space:nowrap}.tile-code::before{font-size:7px}.tile-rating{width:82px;height:30px;justify-content:center;margin:0;padding:0 6px;border-radius:0 9px 9px 0}.tile-rating span{font-size:8px}.tile-rating strong{font-size:15px}.tile-more{display:none}.tile-copy h3{font-size:15px}.tile-copy p{font-size:8px}}.tile-top{display:flex;min-width:0;align-items:stretch;justify-content:space-between;gap:8px}.tile-top .tile-code{position:static;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-top .tile-rating{flex:none}.tile-copy{color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.95)}.tile-copy p{color:#e3dfe7}.tile-copy h3{display:-webkit-box;overflow:hidden;color:#fff;-webkit-box-orient:vertical;-webkit-line-clamp:2}@media(max-width:620px){.tile-top{width:100%;height:34px;gap:0;overflow:hidden;border:1px solid rgba(255,255,255,.28);border-radius:10px;background:rgba(7,7,12,.94);box-shadow:0 3px 12px rgba(0,0,0,.45);backdrop-filter:blur(10px)}.tile-top .tile-code{position:static;right:auto;left:auto;flex:auto;height:auto;padding:0 9px;border:0;border-radius:0;background:0 0;box-shadow:none;backdrop-filter:none}.tile-top .tile-rating{flex:0 0 56px;width:56px;height:auto;padding:0 7px;border:0;border-left:1px solid rgba(255,255,255,.2);border-radius:0;background:0 0;box-shadow:none;backdrop-filter:none}.tile-top .tile-rating span{display:none}.tile-top .tile-rating strong{font-size:16px}.tile-top .tile-rating small{display:none}.tile-copy{padding-top:24px}.tile-copy p{color:#f0edf3}}