/* Portfolio Showcase Pro — frontend (screenshot-matched design) */
.psc-wrap{--psc-black:#111;--psc-yellow:#f5c518;--psc-gray:#777;--psc-border:#e8e8e8;--psc-bg:#f4f4f4;
	font-family:'Poppins','Segoe UI',system-ui,sans-serif;color:var(--psc-black);max-width:1200px;margin:0 auto;padding:0 12px}
.psc-wrap *,.psc-wrap *::before,.psc-wrap *::after{box-sizing:border-box}

/* ── Filter bar ───────────────────────────── */
.psc-filterbar{background:var(--psc-bar,var(--psc-black));border-radius:14px;padding:14px 18px;display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:34px;box-shadow:0 10px 30px rgba(0,0,0,.18)}
.psc-select-wrap{position:relative}
.psc-filterbar select,.psc-search-wrap{background:#fff;border:0;border-radius:8px;height:42px;font-size:13px;font-weight:500}
.psc-filterbar select{appearance:none;-webkit-appearance:none;padding:0 38px 0 16px;min-width:160px;cursor:pointer;color:#222;
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
	background-repeat:no-repeat;background-position:right 14px center}
.psc-search-wrap{display:flex;align-items:center;flex:1 1 260px;min-width:220px;padding:0 6px 0 16px}
.psc-search-wrap input{border:0;outline:0;flex:1;font-size:13px;background:transparent;min-width:0;height:100%}
.psc-search-btn{background:var(--psc-bg);border:0;border-radius:6px;width:32px;height:32px;display:grid;place-items:center;cursor:pointer;color:#111}
.psc-search-btn:hover{background:var(--psc-yellow)}
.psc-reset{margin-left:auto;background:transparent;border:0;color:#fff;font-size:13px;font-weight:500;display:inline-flex;gap:8px;align-items:center;cursor:pointer;padding:8px 10px;border-radius:8px}
.psc-reset:hover{background:rgba(255,255,255,.12)}
.psc-reset svg{transition:transform .4s}
.psc-reset:hover svg{transform:rotate(-180deg)}

/* ── Grid & cards ─────────────────────────── */
.psc-grid{display:grid;grid-template-columns:repeat(var(--psc-cols,3),1fr);gap:28px}
@media(max-width:980px){.psc-grid{grid-template-columns:repeat(min(var(--psc-cols,3),2),1fr)}}
@media(max-width:640px){.psc-grid{grid-template-columns:1fr}.psc-reset{margin-left:0}}
.psc-card{background:#fff;border:1px solid var(--psc-border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s}
.psc-card:hover{box-shadow:0 14px 36px rgba(0,0,0,.12);transform:translateY(-3px)}
.psc-card-media{position:relative;height:var(--psc-img-h,340px);overflow:hidden;background:#fafafa;cursor:zoom-in}
.psc-card-img{width:100%;height:auto;min-height:100%;object-fit:cover;object-position:top;display:block;transition:object-position 4s ease}
.psc-card:hover .psc-card-img{object-position:bottom} /* long screenshot scroll effect */
.psc-noimg{height:100%;display:grid;place-items:center;color:#bbb;font-size:13px}

.psc-card-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:10px;flex:1}
.psc-card-title{margin:0;font-size:17px;font-weight:600;letter-spacing:.2px;display:flex;align-items:center;gap:8px}
.psc-preview-link{display:inline-flex;align-items:center;color:#999;transition:color .2s,transform .2s;line-height:1;background:none;border:0;padding:0;cursor:pointer}
.psc-preview-link:hover{color:var(--psc-yellow);transform:scale(1.15)}
.psc-card-tags{display:flex;flex-wrap:wrap;gap:6px 14px}
.psc-tag-chip{background:none;border:0;padding:0;color:var(--psc-gray);font-size:12.5px;cursor:pointer;font-family:inherit}
.psc-tag-chip:hover{color:var(--psc-black);text-decoration:underline}
.psc-card-actions{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:10px}
.psc-action{background:none;border:0;padding:0 0 5px;font:600 13.5px/1 inherit;font-family:inherit;color:var(--psc-black);cursor:pointer;text-decoration:none;position:relative;display:inline-flex;align-items:center;gap:7px}
.psc-action::after{content:"";position:absolute;left:0;bottom:0;height:3px;width:34px;background:var(--psc-yellow);border-radius:2px;transition:width .25s}
.psc-action:hover::after{width:100%}
.psc-action.psc-static{pointer-events:none;cursor:default}
.psc-arrow{transition:transform .25s}
.psc-demo:hover .psc-arrow{transform:translateX(4px)}
.psc-btn-icon{font-size:14px;line-height:1;display:inline-block;transition:transform .25s}
.psc-action:hover .psc-btn-icon{transform:scale(1.15)}
.psc-empty{grid-column:1/-1;text-align:center;padding:70px 20px;color:#888;font-size:15px;background:#fafafa;border-radius:10px}

/* loading state */
.psc-grid.psc-loading{opacity:.45;pointer-events:none;filter:saturate(.6)}
.psc-loadmore-wrap{text-align:center;margin:34px 0 10px}
.psc-loadmore{background:var(--psc-black);color:#fff;border:0;border-radius:8px;padding:13px 34px;font:600 13.5px inherit;font-family:inherit;cursor:pointer;transition:.2s}
.psc-loadmore:hover{background:#000;box-shadow:0 8px 20px rgba(0,0,0,.2)}
.psc-loadmore[hidden]{display:none}

/* numbered pagination */
.psc-pager{display:flex;justify-content:center;gap:8px;margin:34px 0 10px;flex-wrap:wrap}
.psc-page-btn{min-width:42px;height:42px;border:1px solid var(--psc-border,#e8e8e8);background:#fff;border-radius:8px;font:600 13.5px inherit;font-family:inherit;cursor:pointer;color:var(--psc-black,#111);transition:.2s;padding:0 12px}
.psc-page-btn:hover{border-color:#111}
.psc-page-btn.is-active{background:var(--psc-black,#111);color:#fff;border-color:var(--psc-black,#111)}
.psc-page-dots{border:0;background:none;cursor:default}

/* infinite scroll spinner */
.psc-infinite-spin{display:inline-block;width:26px;height:26px;border:3px solid var(--psc-border,#e8e8e8);border-top-color:var(--psc-black,#111);border-radius:50%;animation:pscSpin .7s linear infinite}
.psc-infinite-spin[hidden]{display:none}
@keyframes pscSpin{to{transform:rotate(360deg)}}

/* ── Lightbox (full image fit, no scrollbar) ── */
.psc-lightbox{position:fixed;inset:0;z-index:99999;background:rgba(10,10,10,.92);display:flex;align-items:center;justify-content:center}
.psc-lightbox[hidden]{display:none}
.psc-lb-stage{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh}
.psc-lb-stage img{display:block;max-width:88vw;max-height:86vh;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.psc-lb-close,.psc-lb-prev,.psc-lb-next{position:fixed;background:rgba(255,255,255,.12);border:0;color:#fff;cursor:pointer;border-radius:50%;display:grid;place-items:center;transition:.2s}
.psc-lb-close{top:22px;right:26px;width:46px;height:46px;font-size:26px}
.psc-lb-prev,.psc-lb-next{top:50%;transform:translateY(-50%);width:50px;height:50px;font-size:20px}
.psc-lb-prev{left:24px}.psc-lb-next{right:24px}
.psc-lb-close:hover,.psc-lb-prev:hover,.psc-lb-next:hover{background:var(--psc-yellow,#f5c518);color:#111}
.psc-lb-count{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);color:#ddd;font-size:13px;letter-spacing:1px}

/* ── View Demo OTP modal ──────────────────── */
.psc-modal{position:fixed;inset:0;z-index:99998;background:rgba(15,15,15,.6);display:flex;align-items:center;justify-content:center;padding:18px;backdrop-filter:blur(3px)}
.psc-modal[hidden]{display:none}
.psc-modal-card{background:#fff;border-radius:14px;width:100%;max-width:420px;padding:30px 28px;position:relative;box-shadow:0 30px 70px rgba(0,0,0,.35);animation:pscPop .25s ease}
@keyframes pscPop{from{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}
.psc-modal-close{position:absolute;top:12px;right:14px;background:none;border:0;font-size:24px;cursor:pointer;color:#999;line-height:1}
.psc-modal-close:hover{color:#111}
.psc-modal-card h3{margin:0 0 4px;font-size:20px}
.psc-modal-sub{margin:0 0 18px;color:#777;font-size:13px}
.psc-step label{display:block;font-size:12.5px;font-weight:600;margin-bottom:14px;color:#333}
.psc-step input{display:block;width:100%;margin-top:6px;height:44px;border:1.5px solid var(--psc-border,#e8e8e8);border-radius:8px;padding:0 14px;font-size:14px;outline:0;transition:border-color .2s}
.psc-step input:focus{border-color:#111}
#psc-f-otp{letter-spacing:8px;font-size:18px;text-align:center;font-weight:700}
.psc-btn-primary{width:100%;background:#111;color:#fff;border:0;border-radius:8px;height:46px;font:600 14px inherit;font-family:inherit;cursor:pointer;transition:.2s}
.psc-btn-primary:hover{background:#000}
.psc-btn-primary:disabled{opacity:.55;cursor:wait}
.psc-btn-link{display:block;width:100%;margin-top:10px;background:none;border:0;color:#555;font-size:12.5px;cursor:pointer;text-decoration:underline;font-family:inherit}
.psc-otp-note{font-size:13px;color:#2c7a3f;background:#eef9f0;border-radius:8px;padding:10px 12px;margin:0 0 14px}
.psc-msg{margin-top:12px;font-size:13px;min-height:18px}
.psc-msg.is-error{color:#c0392b}
.psc-msg.is-success{color:#2c7a3f}
