.portfolio-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);background:#0a0a0ae0;justify-content:center;align-items:center;padding:20px;animation:.3s overlayFadeIn;display:flex;position:fixed;inset:0}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.portfolio-modal{border-radius:var(--radius-xl);background:#fff;width:100%;max-width:900px;max-height:85vh;animation:.4s cubic-bezier(.22,1,.36,1) modalSlideIn;position:relative;overflow:hidden;box-shadow:0 30px 80px #0006}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.94)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.portfolio-modal-close{-webkit-backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:1001;background:#00000080;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:22px;font-weight:300;transition:all .3s;display:flex;position:absolute;top:16px;right:16px}.portfolio-modal-close:hover{background:#dc2626b3;border-color:#ffffff4d;transform:scale(1.08)}.portfolio-modal-content{flex-direction:column;height:100%;min-height:0;max-height:85vh;display:flex}.portfolio-modal-header{display:none}.portfolio-modal-media{flex:1;grid-template-columns:1fr 280px;align-items:start;gap:20px;min-width:0;min-height:0;padding:20px;display:grid;overflow-y:auto}.portfolio-modal-photos{margin-bottom:0}.photo-viewer{background:var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;width:100%;height:320px;margin-bottom:12px;transition:transform .2s;position:relative;overflow:hidden}.photo-viewer:hover{transform:scale(1.005)}.photo-zoom-hint{-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;z-index:5;background:#00000073;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:opacity .3s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.photo-viewer:hover .photo-zoom-hint{opacity:1}@media (max-width:768px){.photo-zoom-hint{opacity:.65;width:42px;height:42px}.photo-zoom-hint svg{width:22px;height:22px}}.photo-main{object-fit:cover;width:100%;height:100%;display:block}.photo-error{color:#b91c1c;text-align:center;background:#fef2f2;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.photo-error .error-icon{margin-bottom:12px;font-size:44px}.photo-nav{-webkit-backdrop-filter:blur(8px);color:var(--text-primary);cursor:pointer;z-index:10;background:#ffffffe0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:15px;transition:all .25s;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 2px 10px #0000001f}.photo-nav:hover:not(:disabled){background:#fff;transform:translateY(-50%)scale(1.08);box-shadow:0 4px 16px #0000002e}.photo-nav:disabled{opacity:.35;cursor:not-allowed;background:#ffffff80}.photo-nav-prev{left:14px}.photo-nav-next{right:14px}.photo-counter{-webkit-backdrop-filter:blur(10px);color:#fff;letter-spacing:.02em;background:#0000008c;border:1px solid #ffffff1a;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.photo-thumbnails{flex-wrap:wrap;gap:6px;padding:6px 0;display:flex}.photo-thumbnail{border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-tertiary);border:2px solid #0000;flex-shrink:0;justify-content:center;align-items:center;width:58px;height:58px;transition:all .25s;display:flex;overflow:hidden}.photo-thumbnail:hover{border-color:var(--primary-color);transform:scale(1.06)}.photo-thumbnail.active{border-color:var(--primary-color);box-shadow:0 0 0 3px #00a33e2e}.photo-thumbnail img{object-fit:cover;width:100%;height:100%}.thumbnail-error{color:#b91c1c;font-size:18px}.video-container{background:var(--bg-tertiary);border-radius:var(--radius-md);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.video-fallback{background:var(--bg-tertiary);min-height:200px;color:var(--text-tertiary);border-radius:var(--radius-md);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:20px;display:flex}.fallback-icon{margin-bottom:12px;font-size:44px}.no-media{background:var(--bg-tertiary);width:100%;height:100%;color:var(--text-tertiary);text-align:center;border-radius:var(--radius-md);flex-direction:column;justify-content:center;align-items:center;display:flex}.no-media-icon{opacity:.5;margin-bottom:12px;font-size:44px}.video-thumbnail{background:var(--bg-tertiary);border:2px solid #0000;position:relative}.video-thumbnail-content{width:100%;height:100%;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.video-play-icon{margin-bottom:3px;font-size:18px}.video-thumbnail:hover{border-color:var(--primary-color);background:#e2e8f0}.video-thumbnail.active{background:var(--primary-color);color:#fff;border-color:var(--primary-dark)}.video-thumbnail.active .video-thumbnail-content{color:#fff}.portfolio-modal-sidebar{background:var(--bg-secondary);border-radius:var(--radius-md);height:fit-content;padding:24px}.portfolio-modal-info{flex-direction:column;gap:14px;display:flex}.portfolio-modal-title{font-family:var(--font-heading);font-size:1.35rem;font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:-.01em;margin:0;line-height:1.3}.portfolio-modal-description{color:var(--text-tertiary);margin:0;font-size:.9rem;line-height:1.6}.portfolio-modal-video-iframe{border-radius:var(--radius-md);width:100%;max-width:100%;height:100%;overflow:hidden}.portfolio-modal-footer{border-top:1px solid var(--border-color);flex-shrink:0;padding:12px 20px;display:none}@media (max-width:768px){.portfolio-modal{border-radius:var(--radius-lg);max-width:95vw;max-height:95vh;margin:10px}.portfolio-modal-content{max-height:95vh}.portfolio-modal-title{font-size:1.2rem}.portfolio-modal-media{grid-template-columns:1fr;gap:16px;min-height:0;padding:16px;overflow:hidden auto}.photo-viewer{height:260px;min-height:260px;max-height:260px}.photo-nav{width:36px;height:36px;font-size:14px}.photo-thumbnail{width:50px;height:50px}.portfolio-modal-sidebar{order:-1;width:100%;max-width:100%;padding:18px}.portfolio-modal-photos{width:100%;min-width:0;max-width:100%}.video-container{width:100%;max-width:100%;height:auto;min-height:200px;max-height:260px}.portfolio-modal-video-iframe{width:100%;height:100%;min-height:200px;max-height:260px}}@media (max-width:480px){.portfolio-modal-overlay{padding:8px}.portfolio-modal{border-radius:0;max-width:100vw;max-height:100vh;margin:0}.portfolio-modal-content{max-height:100vh}.portfolio-modal-media{gap:12px;padding:12px}.photo-viewer{height:220px;min-height:220px;max-height:220px}.photo-thumbnail{width:48px;height:48px}.portfolio-modal-sidebar{padding:14px}.video-container,.portfolio-modal-video-iframe{min-height:160px;max-height:220px}}.fullscreen-overlay{z-index:10000;background:#000000f5;justify-content:center;align-items:center;padding:20px;animation:.25s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fullscreen-close{-webkit-backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:10001;background:#ffffff1a;border:1.5px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;font-weight:300;transition:all .3s;display:flex;position:absolute;top:20px;right:20px}.fullscreen-close:hover{background:#dc2626b3;border-color:#fff6;transform:scale(1.08)rotate(90deg)}.fullscreen-close:active{transform:scale(.95)rotate(90deg)}.fullscreen-close i{font-size:18px}.fullscreen-content{justify-content:center;align-items:center;width:100%;max-width:95vw;height:100%;max-height:95vh;display:flex;position:relative}.fullscreen-image{object-fit:contain;border-radius:var(--radius-md);width:auto;max-width:100%;height:auto;max-height:100%;box-shadow:0 12px 50px #00000080}.fullscreen-video-container{border-radius:var(--radius-md);justify-content:center;align-items:center;width:100%;max-width:95vw;height:100%;max-height:95vh;display:flex;overflow:hidden;box-shadow:0 12px 50px #00000080}.fullscreen-video-iframe{border-radius:var(--radius-md);width:100%;max-width:100%;height:100%;max-height:100%}.fullscreen-error,.fullscreen-no-media{color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:40px;display:flex}.fullscreen-error{border-radius:var(--radius-md);background:#b91c1c26}.fullscreen-error .error-icon{margin-bottom:16px;font-size:56px}.fullscreen-no-media{border-radius:var(--radius-md);background:#71809626}.fullscreen-no-media .no-media-icon{opacity:.5;margin-bottom:16px;font-size:56px}.fullscreen-nav{-webkit-backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:10001;background:#ffffff1f;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:22px;transition:all .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.fullscreen-nav:hover:not(:disabled){background:#ffffff38;border-color:#ffffff4d;transform:translateY(-50%)scale(1.08)}.fullscreen-nav:disabled{opacity:.25;cursor:not-allowed}.fullscreen-nav-prev{left:20px}.fullscreen-nav-next{right:20px}.fullscreen-counter{-webkit-backdrop-filter:blur(10px);color:#fff;letter-spacing:.02em;background:#0000008c;border:1px solid #ffffff1a;border-radius:24px;padding:10px 22px;font-size:14px;font-weight:600;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}@media (max-width:768px){.fullscreen-close{width:42px;height:42px;font-size:18px;top:16px;right:12px}.fullscreen-close i{font-size:16px}.fullscreen-nav{width:48px;height:48px;font-size:18px}}@media (max-width:480px){.fullscreen-close{width:38px;height:38px;font-size:16px;top:12px;right:10px}.fullscreen-close i{font-size:14px}.fullscreen-nav{width:42px;height:42px;font-size:16px}.fullscreen-nav-prev{left:10px}.fullscreen-nav-next{right:10px}.fullscreen-counter{padding:8px 18px;font-size:12px;bottom:12px}}
.portfolio-page{min-height:calc(100vh - 200px)}.portfolio-section{background:var(--bg-primary);padding:8rem 0 6rem;position:relative;overflow:hidden}.portfolio-section:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(600px 400px at 10% 20%,#00a33e0a,#0000),radial-gradient(500px 500px at 90% 80%,#00a33e08,#0000);position:absolute;inset:0}.section-header{text-align:center;z-index:1;margin-bottom:4rem;position:relative}.section-title{font-family:var(--font-heading);font-size:clamp(2.4rem,5vw,3.6rem);font-weight:var(--font-weight-extrabold);color:var(--text-primary);letter-spacing:-.03em;margin:0 0 1.2rem;line-height:1.1;display:inline-block;position:relative}.section-title:after{content:"";background:var(--primary-gradient);border-radius:2px;width:60px;height:3px;position:absolute;bottom:-12px;left:50%;transform:translate(-50%)}.section-description{color:var(--text-tertiary);max-width:540px;font-size:1.15rem;line-height:1.7;font-weight:var(--font-weight-normal);margin:2rem auto 0}.portfolio-grid{z-index:1;grid-template-columns:repeat(3,1fr);grid-auto-rows:280px;gap:1.25rem;margin-bottom:3.5rem;display:grid;position:relative}.portfolio-card:first-child,.portfolio-card:nth-child(4){grid-row:span 2}.portfolio-card{border-radius:var(--radius-lg);cursor:pointer;background:var(--bg-tertiary);transition:box-shadow .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1);animation:.7s cubic-bezier(.22,1,.36,1) both cardReveal;position:relative;overflow:hidden;box-shadow:0 2px 12px #0000000f}.portfolio-card:first-child{animation-delay:50ms}.portfolio-card:nth-child(2){animation-delay:.12s}.portfolio-card:nth-child(3){animation-delay:.19s}.portfolio-card:nth-child(4){animation-delay:.26s}.portfolio-card:nth-child(5){animation-delay:.33s}.portfolio-card:nth-child(6){animation-delay:.4s}@keyframes cardReveal{0%{opacity:0;transform:translateY(30px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.portfolio-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px #00000024,0 0 0 1px #00a33e14}.portfolio-media{background:var(--bg-tertiary);width:100%;height:100%;position:absolute;inset:0;overflow:hidden}.portfolio-photos{width:100%;height:100%;position:relative}.portfolio-main-photo{object-fit:cover;width:100%;height:100%;transition:transform .7s cubic-bezier(.22,1,.36,1),filter .5s;display:block}.portfolio-card:hover .portfolio-main-photo{filter:brightness(.75);transform:scale(1.06)}.portfolio-error-placeholder{color:#b91c1c;text-align:center;background:#fef2f2;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;font-size:14px;display:flex}.portfolio-error-placeholder .error-icon{opacity:.6;margin-bottom:8px;font-size:28px}.photo-count{-webkit-backdrop-filter:blur(12px);color:#fff;letter-spacing:.02em;z-index:3;background:#00000073;border:1px solid #ffffff1f;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;transition:transform .3s,opacity .3s;position:absolute;top:16px;right:16px}.portfolio-card:hover .photo-count{transform:translateY(-2px)}.video-play-overlay{z-index:2;background:#00000026;justify-content:center;align-items:center;transition:background .4s;display:flex;position:absolute;inset:0}.portfolio-card:hover .video-play-overlay{background:#00000059}.video-play-button{cursor:pointer;background:#ffffffeb;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s;display:flex;box-shadow:0 4px 20px #0003}.portfolio-card:hover .video-play-button{transform:scale(1.12);box-shadow:0 8px 30px #0000004d}.play-icon{color:var(--text-primary);margin-left:3px;font-size:20px}.portfolio-content{z-index:2;opacity:0;background:linear-gradient(#0000 0%,#00000073 50%,#000000c7 100%);padding:60px 24px 24px;transition:transform .5s cubic-bezier(.22,1,.36,1),opacity .4s;position:absolute;bottom:0;left:0;right:0;transform:translateY(20px)}.portfolio-card:hover .portfolio-content{opacity:1;transform:translateY(0)}.portfolio-title{font-family:var(--font-heading);font-size:1.2rem;font-weight:var(--font-weight-bold);color:#fff;letter-spacing:-.01em;text-shadow:0 1px 4px #0000004d;margin:0 0 10px;line-height:1.3}.portfolio-stats{flex-wrap:wrap;gap:8px;display:flex}.media-count{-webkit-backdrop-filter:blur(8px);color:#ffffffe6;letter-spacing:.01em;background:#ffffff26;border:1px solid #ffffff1a;border-radius:14px;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:500;display:flex}.portfolio-pagination{text-align:center;margin-top:12px}.portfolio-pagination .pagination-controls{flex-wrap:nowrap;justify-content:center;align-items:center;gap:6px;max-width:100%;margin-top:0;padding:0 4px;display:flex}.pagination-btn{color:var(--text-tertiary);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;min-width:38px;height:38px;padding:0;font-size:14px;transition:all .25s;display:flex}.pagination-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary);border-color:var(--primary-color)}.pagination-btn:disabled{color:#d1d5db;cursor:not-allowed;border-color:#f3f4f6}.pagination-pages{flex-wrap:wrap;flex:1;justify-content:center;gap:4px;min-width:0;margin:0 8px;display:flex}.pagination-page{color:var(--text-tertiary);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-weight:var(--font-weight-medium);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;min-width:38px;height:38px;padding:0;font-size:13px;transition:all .25s;display:flex}.pagination-page:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:#00a33e66}.pagination-page.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);font-weight:var(--font-weight-semibold);box-shadow:0 2px 8px #00a33e4d}.pagination-page.active:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.pagination-dots{color:var(--text-tertiary);-webkit-user-select:none;user-select:none;text-align:center;align-items:center;min-width:20px;padding:0 4px;font-weight:500;display:flex}.portfolio-loading,.portfolio-error,.portfolio-empty{text-align:center;min-height:300px;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;display:flex}.loading-spinner{border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;width:36px;height:36px;margin-bottom:16px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-icon,.empty-icon{opacity:.5;margin-bottom:16px;font-size:44px}.retry-button{background:var(--primary-color);color:#fff;border-radius:var(--radius-sm);font-weight:var(--font-weight-semibold);cursor:pointer;border:none;margin-top:16px;padding:10px 24px;font-size:14px;transition:all .25s}.retry-button:hover{background:var(--primary-dark);box-shadow:0 4px 12px #00a33e40}@media (max-width:1024px){.portfolio-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:240px;gap:1rem}.portfolio-card:first-child,.portfolio-card:nth-child(4){grid-row:span 2}}@media (max-width:768px){.portfolio-section{padding:5rem 0 3rem}.section-header{margin-bottom:2.5rem}.portfolio-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px;gap:.75rem}.portfolio-card:first-child,.portfolio-card:nth-child(4){grid-row:span 1}.portfolio-content{opacity:1;background:linear-gradient(#0000 0%,#0000004d 40%,#000000b8 100%);padding:40px 16px 16px;transform:translateY(0)}.portfolio-main-photo{transition:none}.portfolio-card:hover .portfolio-main-photo{filter:none;transform:none}.portfolio-title{margin:0 0 6px;font-size:1rem}.media-count{padding:3px 8px;font-size:10px}.photo-count{padding:3px 9px;font-size:11px;top:10px;right:10px}.pagination-btn{min-width:34px;height:34px;font-size:13px}.portfolio-pagination .pagination-controls{gap:4px}.pagination-pages{gap:3px;margin:0 4px}.pagination-page{min-width:34px;height:34px;font-size:12px}}@media (max-width:480px){.portfolio-section{padding:4rem 0 2rem}.portfolio-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px;gap:.5rem}.portfolio-content{padding:32px 12px 12px}.portfolio-title{margin:0 0 4px;font-size:.85rem}.portfolio-stats{gap:4px}.media-count{gap:3px;padding:2px 6px;font-size:9px}.photo-count{padding:2px 7px;font-size:10px;top:8px;right:8px}.video-play-button{width:44px;height:44px}.play-icon{font-size:16px}.portfolio-pagination .pagination-controls{gap:3px}.pagination-pages{gap:2px;margin:0 2px}.pagination-btn,.pagination-page{min-width:30px;height:30px;font-size:11px}.pagination-dots{min-width:14px;padding:0 2px;font-size:11px}}
