.pg-gallery-container{max-width:1200px;margin:0 auto;padding:0 16px}.pg-gallery-grid{display:grid;gap:24px;margin:32px 0}.pg-grid-cols-1{grid-template-columns:1fr}.pg-grid-cols-2{grid-template-columns:repeat(2,1fr)}.pg-grid-cols-3{grid-template-columns:repeat(3,1fr)}.pg-grid-cols-4{grid-template-columns:repeat(4,1fr)}.pg-project-card{display:flex;flex-direction:column;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px rgb(0 0 0 / .1),0 2px 4px -1px rgb(0 0 0 / .06);transition:all 0.3s ease;cursor:pointer;border:1px solid rgb(229 231 235 / .8)}.pg-project-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px rgb(0 0 0 / .1),0 10px 10px -5px rgb(0 0 0 / .04);border-color:rgb(59 130 246 / .5)}.pg-project-image{position:relative;width:100%;height:240px;overflow:hidden;background:#f8fafc}.pg-project-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s ease}.pg-project-card:hover .pg-project-image img{transform:scale(1.05)}.pg-image-count{position:absolute;top:12px;right:12px;background:rgb(0 0 0 / .7);color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;backdrop-filter:blur(4px)}.pg-project-content{flex:1;display:flex;flex-direction:column;padding:20px}.pg-project-title{font-size:18px;font-weight:700;color:#1f2937;margin:0 0 8px 0;line-height:1.2}.pg-project-description{color:#6b7280;font-size:14px;line-height:1.5;margin:0 0 16px 0;max-height:320px;overflow-y:auto;text-align:justify}.pg-project-description::-webkit-scrollbar{width:1px}.pg-project-description::-webkit-scrollbar-track{background:#f1f5f9;border-radius:2px}.pg-project-description::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.pg-project-description::-webkit-scrollbar-thumb:hover{background:#94a3b8}.pg-view-project{margin-top:auto;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s ease;width:100%;position:relative;overflow:hidden}.pg-view-project::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / .2),transparent);transition:left 0.5s ease}.pg-view-project:hover::before{left:100%}.pg-view-project:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgb(59 130 246 / .4)}.pg-view-project:active{transform:translateY(0)}.pg-no-projects{text-align:center;color:#6b7280;font-size:16px;padding:48px 16px;background:#f9fafb;border-radius:8px;border:1px dashed #d1d5db}.pg-modal{display:none;position:fixed;z-index:999999;left:0;top:0;width:100%;height:100%;background-color:rgb(0 0 0 / .8);backdrop-filter:blur(4px);animation:fadeIn 0.3s ease}.pg-modal.show{display:flex;align-items:center;justify-content:center;padding:20px}.pg-modal-content{background:#fff;border-radius:12px;max-width:1200px;width:98vw;max-height:85vh;position:relative;box-shadow:0 25px 50px -12px rgb(0 0 0 / .25);animation:slideUp 0.3s ease;overflow:hidden}.pg-modal-close{position:absolute;top:20px;right:24px;font-size:24px;font-weight:700;color:#9ca3af;cursor:pointer;z-index:1000;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgb(255 255 255 / .9);transition:all 0.2s ease}.pg-modal-close:hover{color:#374151;background:#f3f4f6;transform:rotate(90deg)}.pg-modal-layout{display:flex;min-height:600px;max-height:85vh}.pg-modal-content-section{flex:2;padding:40px;overflow-y:auto;background:#fff}.pg-modal-gallery-section{flex:1;background:#f8fafc;padding:40px 30px;border-left:1px solid #e5e7eb;display:flex;flex-direction:column}.pg-main-image-container{margin-bottom:10px;position:relative}.pg-main-image{width:100%;height:250px;background:#fff;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer}.pg-main-image img{max-width:100%;max-height:100%;object-fit:contain;display:block;transition:opacity 0.3s ease,transform 0.3s ease}.pg-main-image:hover img{transform:scale(1.02)}.pg-zoom-hint{position:absolute;bottom:8px;right:12px;background:rgb(0 0 0 / .7);color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500;opacity:0;transition:opacity 0.3s ease}.pg-main-image:hover .pg-zoom-hint{opacity:1}.pg-main-image-label{position:absolute;top:8px;left:12px;background:rgb(0 0 0 / .7);color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;z-index:10;backdrop-filter:blur(4px)}.pg-project-details{max-width:100%}.pg-project-details .pg-project-title{font-size:24px;font-weight:700;color:#111827;margin:0 0 24px 0;line-height:1.2;padding-right:50px}.pg-project-meta{margin-bottom:32px}.pg-meta-row{display:flex;margin-bottom:12px;align-items:flex-start}.pg-meta-label{font-size:14px;font-weight:600;color:#6b7280;min-width:80px;margin-right:16px}.pg-meta-value{font-size:14px;color:#374151;font-weight:500}.pg-project-description{margin-bottom:32px}.pg-project-description h3{font-size:18px;font-weight:600;color:#111827;margin:0 0 16px 0}.pg-description-content{font-size:15px;line-height:1.6;color:#4b5563;text-align:justify;max-height:60vh;overflow-y:auto;padding-right:8px}.pg-description-content p{margin-bottom:16px}.pg-description-content p:last-child{margin-bottom:0}.pg-description-content h1,.pg-description-content h2,.pg-description-content h3,.pg-description-content h4,.pg-description-content h5,.pg-description-content h6{color:#111827;margin-top:24px;margin-bottom:12px;font-weight:600}.pg-description-content ul,.pg-description-content ol{margin:16px 0;padding-left:24px}.pg-description-content li{margin-bottom:8px}.pg-description-content strong{font-weight:600;color:#111827}.pg-description-content em{font-style:italic}.pg-description-content a{color:#3b82f6;text-decoration:underline}.pg-description-content a:hover{color:#1d4ed8}.pg-project-focus{background:#f0f9ff;padding:24px;border-radius:8px;border-left:4px solid #3b82f6;margin-top:24px}.pg-project-focus h3{font-size:16px;font-weight:600;color:#1e40af;margin:0 0 12px 0}.pg-focus-content{font-size:14px;line-height:1.5;color:#1e40af;margin:0}.pg-focus-content p{margin-bottom:12px}.pg-focus-content p:last-child{margin-bottom:0}.pg-focus-content ul,.pg-focus-content ol{margin:12px 0;padding-left:20px}.pg-focus-content li{margin-bottom:6px}.pg-focus-content strong{font-weight:600;color:#1e3a8a}.pg-focus-content em{font-style:italic}.pg-focus-content a{color:#1e40af;text-decoration:underline}.pg-focus-content a:hover{color:#1e3a8a}.pg-zoom-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(0 0 0 / .9);z-index:999999;cursor:pointer}.pg-zoom-modal.show{display:flex;align-items:center;justify-content:center;animation:fadeIn 0.3s ease}.pg-zoom-modal img{max-width:95%;max-height:95%;object-fit:contain;border-radius:8px;animation:zoomIn 0.3s ease}.pg-zoom-close{position:absolute;top:20px;right:30px;font-size:32px;color:#fff;cursor:pointer;font-weight:700;z-index:1000000}.pg-zoom-close:hover{color:#f3f4f6}.pg-modal-gallery-section .pg-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;flex:1}.pg-gallery-item{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;transition:all 0.2s ease;border:2px solid #fff0}.pg-gallery-item:hover,.pg-gallery-item.active{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px rgb(59 130 246 / .15)}.pg-gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.2s ease}.pg-gallery-item:hover img{transform:scale(1.05)}.pg-gallery-counter{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb;font-size:14px;color:#6b7280;font-weight:500}.pg-gallery-counter .pg-current{color:#3b82f6;font-weight:600}.pg-loading{display:inline-block;width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.no-js .pg-project-card,.pg-project-card.pg-fallback-visible{opacity:1!important;transform:translateY(0)!important}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes zoomIn{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@keyframes pulse{0%,100%{opacity:.4}50%{opacity:.8}}@media (max-width:1024px){.pg-grid-cols-4{grid-template-columns:repeat(3,1fr)}.pg-grid-cols-3{grid-template-columns:repeat(2,1fr)}.pg-modal-content{width:90vw;max-width:1000px}.pg-modal-content-section{padding:30px}.pg-modal-gallery-section{padding:30px 25px}}@media (max-width:768px){.pg-gallery-container{padding:0 12px;min-height:300px}.pg-gallery-grid{display:grid!important;grid-template-columns:1fr!important;gap:16px;margin:20px 0;padding-bottom:60px}.pg-grid-cols-4,.pg-grid-cols-3,.pg-grid-cols-2{grid-template-columns:1fr}.pg-project-card{display:flex!important;flex-direction:column;min-height:250px;width:100%;margin-bottom:20px;opacity:1!important;transform:translateY(0)!important;animation:none!important}.pg-project-card:last-child{margin-bottom:80px!important}.pg-project-image{height:200px;display:block}.pg-project-image img{width:100%;height:100%;object-fit:cover;display:block}.pg-project-content{padding:16px}.pg-modal-content{width:95vw;margin:10px;max-height:90vh}.pg-modal-layout{flex-direction:column}.pg-modal-content-section{flex:1;padding:24px;order:2}.pg-modal-gallery-section{flex:0 0 auto;height:auto;min-height:340px;padding:20px;border-left:none;border-bottom:1px solid #e5e7eb;order:1}.pg-main-image-container{margin-bottom:20px}.pg-main-image{height:200px}.pg-modal-gallery-section .pg-gallery-grid{grid-template-columns:repeat(3,1fr)!important;gap:12px;height:auto;min-height:100px;margin-bottom:16px}.pg-gallery-item{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;transition:all 0.2s ease;border:2px solid #e5e7eb;background:#fff;box-shadow:0 2px 4px rgb(0 0 0 / .1);position:relative;min-height:80px}.pg-gallery-item:hover,.pg-gallery-item.active{border-color:#3b82f6!important;transform:translateY(-2px);box-shadow:0 4px 12px rgb(59 130 246 / .25);background:#f8fafc}.pg-gallery-counter{text-align:center;margin-top:16px;padding:12px;border-top:1px solid #e5e7eb;font-size:14px;color:#6b7280;font-weight:500;background:#f8fafc;border-radius:6px}.pg-gallery-counter .pg-current{color:#3b82f6;font-weight:600;font-size:16px}.pg-project-details .pg-project-title{font-size:18px;padding-right:20px;margin-bottom:10px}.pg-project-meta{margin-bottom:20px}.pg-meta-row{margin-bottom:8px}.pg-meta-label{min-width:70px;font-size:13px}.pg-meta-value{font-size:13px}.pg-project-description h3{font-size:16px;margin-bottom:12px}.pg-description-content{font-size:14px}.pg-project-focus{padding:20px;margin-bottom:0}.pg-project-focus h3{font-size:15px}.pg-focus-content{font-size:13px}}@media (max-width:480px){.pg-gallery-container{padding:0 15px;padding-bottom:0}.pg-project-card:last-child{margin-bottom:10px!important}.pg-project-image{height:220px}.pg-project-content{padding:12px}.pg-project-title{font-size:16px}.pg-project-description{font-size:13px;margin-bottom:16px}.pg-view-project{padding:8px 16px;font-size:13px;margin-bottom:8px}.pg-modal-content-section{padding:40px}.pg-modal-gallery-section{height:auto;min-height:380px;padding:16px}.pg-main-image-container{margin-bottom:20px}.pg-main-image{height:180px}.pg-modal-gallery-section .pg-gallery-grid{grid-template-columns:repeat(3,1fr)!important;gap:10px;height:auto;min-height:120px;padding:8px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.pg-gallery-item{aspect-ratio:1;border-radius:6px;overflow:hidden;cursor:pointer;transition:all 0.2s ease;border:2px solid #d1d5db;background:#fff;box-shadow:0 2px 6px rgb(0 0 0 / .12);position:relative;min-height:85px;max-height:100px}.pg-gallery-item:hover,.pg-gallery-item.active{border-color:#3b82f6!important;transform:translateY(-3px);box-shadow:0 6px 16px rgb(59 130 246 / .3);background:#eff6ff;z-index:10}.pg-gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.2s ease;border-radius:4px}.pg-gallery-item:active{transform:scale(.95);transition:transform 0.1s ease}.pg-gallery-item::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:#e5e7eb;border-radius:50%;opacity:0;transition:opacity 0.3s ease}.pg-gallery-item.loading::before{opacity:1;animation:pulse 1.5s ease-in-out infinite}.pg-gallery-counter{text-align:center;margin-top:16px;padding:12px 16px;border-top:1px solid #e5e7eb;font-size:13px;color:#6b7280;font-weight:500;background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border-radius:8px;border:1px solid #e5e7eb}.pg-gallery-counter .pg-current{color:#3b82f6;font-weight:700;font-size:15px}.pg-project-details .pg-project-title{font-size:18px;margin-bottom:16px}.pg-project-meta{margin-bottom:16px}.pg-project-focus{padding:16px}}@media (max-width:375px){.pg-modal-gallery-section .pg-gallery-grid{grid-template-columns:repeat(3,1fr)!important;gap:8px;padding:6px}.pg-gallery-item{min-height:75px;max-height:90px;border-width:1.5px}.pg-gallery-counter{padding:10px 12px;font-size:12px;margin-top:12px}.pg-gallery-counter .pg-current{font-size:14px}}@media (prefers-color-scheme:dark){.pg-project-card{background:#374151;border-color:rgb(75 85 99 / .8)}.pg-project-card:hover{border-color:rgb(96 165 250 / .5)}.pg-project-title{color:#f9fafb}.pg-project-description{color:#d1d5db}.pg-no-projects{background:#374151;color:#d1d5db;border-color:#4b5563}.pg-modal-content{background:#1f2937}.pg-modal-content-section{background:#1f2937}.pg-modal-gallery-section{background:#111827;border-color:#374151}.pg-project-details .pg-project-title{color:#f9fafb}.pg-meta-label{color:#9ca3af}.pg-meta-value{color:#e5e7eb}.pg-project-description h3{color:#f9fafb}.pg-description-content{color:#d1d5db}.pg-project-focus{background:#1e3a8a;border-color:#3b82f6}.pg-project-focus h3{color:#93c5fd}.pg-focus-content{color:#dbeafe}.pg-gallery-item:hover,.pg-gallery-item.active{border-color:#60a5fa}.pg-gallery-counter{color:#9ca3af;border-color:#374151}.pg-gallery-counter .pg-current{color:#60a5fa}.pg-modal-close{color:#d1d5db;background:rgb(31 41 55 / .9)}.pg-modal-close:hover{color:#f9fafb;background:#374151}}@media (prefers-color-scheme:dark) and (max-width:480px){.pg-modal-gallery-section .pg-gallery-grid{background:#1f2937;border-color:#374151}.pg-gallery-item{border-color:#4b5563;background:#374151;box-shadow:0 2px 6px rgb(0 0 0 / .3)}.pg-gallery-item:hover,.pg-gallery-item.active{border-color:#60a5fa!important;background:#1e3a8a;box-shadow:0 6px 16px rgb(96 165 250 / .3)}.pg-gallery-counter{background:linear-gradient(135deg,#1f2937 0%,#111827 100%);border-color:#374151;color:#9ca3af}.pg-gallery-counter .pg-current{color:#60a5fa}}@media (prefers-contrast:high){.pg-project-card{border:2px solid #000}.pg-project-card:hover{border-color:#06c}.pg-view-project{background:#06c;border:2px solid #000}.pg-view-project:hover{background:#0052a3}}@media (prefers-contrast:high) and (max-width:480px){.pg-gallery-item{border-width:3px;border-color:#000}.pg-gallery-item:hover,.pg-gallery-item.active{border-color:#0066cc!important;background:#fff}}@media (prefers-reduced-motion:reduce){.pg-project-card,.pg-project-image img,.pg-view-project,.pg-modal,.pg-modal-content,.pg-gallery-item img{transition:none}.pg-project-card:hover{transform:none}.pg-project-card:hover .pg-project-image img{transform:none}.pg-view-project:hover{transform:none}.pg-gallery-item:hover img{transform:none}}