.port-section{background:#f5f7ff;padding:64px 0 80px}.port-intro{text-align:center;margin-bottom:48px}.port-intro__text{color:#666;max-width:560px;margin:0 auto;font-size:16px;line-height:1.7}.port-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.port-item{position:relative}.port-item__link{aspect-ratio:4/5;background:#e8edf5;border:1px solid #e5ebff;border-radius:14px;display:block;position:relative;overflow:hidden}.port-item__img{object-fit:cover;object-position:top center;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}.port-item:hover .port-item__img{transform:scale(1.05)}.port-item__overlay{opacity:0;visibility:hidden;z-index:2;background:linear-gradient(#0000 0%,#031e6959 45%,#031e69e6 100%);border-radius:14px;align-items:flex-end;padding:22px;transition:opacity .3s,visibility .3s;display:flex;position:absolute;inset:0}.port-item:hover .port-item__overlay{opacity:1;visibility:visible}.port-item__info{transition:transform .3s;transform:translateY(10px)}.port-item:hover .port-item__info{transform:translateY(0)}.port-item__cat{color:#fff;letter-spacing:.8px;text-transform:uppercase;background:#ffffff2e;border:1px solid #ffffff4d;border-radius:20px;margin-bottom:7px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.port-item__title{color:#fff;margin:0 0 5px;font-size:16px;font-weight:700;line-height:1.3}.port-item__cta{color:#ffffffbf;font-size:13px;font-weight:600}@keyframes port-shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.port-skeleton{aspect-ratio:4/5;background:linear-gradient(90deg,#e8edf5 25%,#dde3f0 50%,#e8edf5 75%) 0 0/1200px 100%;border-radius:14px;animation:1.4s linear infinite port-shimmer}.port-empty{text-align:center;color:#bbb;grid-column:1/-1;padding:80px 20px}.port-empty i{margin-bottom:12px;font-size:48px;display:block}.port-end{text-align:center;color:#aaa;margin-top:40px;font-size:14px}@media (max-width:991px){.port-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:575px){.port-section{padding:40px 0 60px}.port-grid{grid-template-columns:1fr;gap:14px}.port-item__overlay{opacity:1;visibility:visible}.port-item__info{transform:none}}.page-portfolio .portfolio-button{display:none}
