:root{--ios-bg-color:#f2f2f7;--ios-text-color:#000;--ios-accent-color:#2da337;--ios-caption-bg:hsla(0,0%,100%,.85);--ios-border-radius:10px;--ios-border-color:rgba(0,0,0,.1);--ios-shadow:0 2px 8px rgba(0,0,0,.1);--ios-transition:all 0.3s ease}@media (prefers-color-scheme:dark){:root{--ios-bg-color:#1c1c1e;--ios-text-color:#fff;--ios-accent-color:#2da337;--ios-caption-bg:rgba(30,30,30,.85);--ios-border-color:hsla(0,0%,100%,.15);--ios-shadow:0 2px 8px rgba(0,0,0,.3)}}.ios-photos{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:var(--ios-bg-color);color:var(--ios-text-color);min-height:100vh;padding:1rem;box-sizing:border-box;max-width:1200px;margin:0 auto;height:100%;width:100%;display:flex;flex-direction:column}.floating-widget-memes .ios-photos{background:transparent;max-width:100%;min-height:100%;padding:.5rem}.floating-widget-memes .photos-header{padding:10px 12px;border-bottom:1px solid hsla(0,0%,100%,.08);background:rgba(15,23,42,.45);border-radius:12px;margin-bottom:8px;-webkit-backdrop-filter:saturate(180%) blur(18px);backdrop-filter:saturate(180%) blur(18px)}.floating-widget-memes .photos-header h1{font-size:1.1rem}.floating-widget-memes .photos-pagination{font-size:.75rem;opacity:.7}.floating-widget-memes .photos-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;padding:8px 8px 60px;border-radius:14px;background:rgba(15,23,42,.28);-webkit-backdrop-filter:saturate(170%) blur(16px);backdrop-filter:saturate(170%) blur(16px)}.floating-widget-memes .photo-caption{font-size:.7rem;padding:.35rem}.photos-header{padding:16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--ios-separator)}.photos-header h1{font-size:1.75rem;font-weight:600;margin:0}.photos-pagination{font-size:.9rem;color:var(--ios-text-color);opacity:.8}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:12px;gap:12px;overflow-y:auto;flex:1 1;-webkit-overflow-scrolling:touch;padding:16px 16px 120px}.photo-item{position:relative;aspect-ratio:1;overflow:hidden;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1);cursor:pointer;transition:transform .2s;display:flex;flex-direction:column}.photo-item:active{transform:scale(.97)}.photo-item img{width:100%;height:calc(100% - 2rem);object-fit:cover;display:block}.photo-caption{position:absolute;bottom:0;left:0;right:0;background-color:var(--ios-caption-bg);padding:.5rem;font-size:.85rem;font-weight:500;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-top:1px solid var(--ios-border-color);z-index:5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading-indicator,.no-photos,.photo-caption{text-align:center;color:var(--ios-text-color)}.loading-indicator,.no-photos{grid-column:1/-1;padding:2rem;opacity:.7;font-size:1rem}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:1rem;margin:1rem 0}.page-button{background-color:var(--ios-accent-color);color:#fff;border:none;border-radius:20px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;transition:var(--ios-transition)}.page-button:disabled{opacity:.5;cursor:not-allowed}.page-button:focus:not(:disabled),.page-button:hover:not(:disabled){background-color:#0056b3;transform:translateY(-2px)}.page-button:focus{outline:2px solid #0056b3;outline-offset:2px}.page-indicator{font-size:.9rem;color:var(--ios-text-color)}.photo-detail-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.9);z-index:1000;display:flex;flex-direction:column;animation:fadeIn .3s ease;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.photo-detail-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:rgba(0,0,0,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.photo-detail-title{color:#fff;font-size:1.1rem;font-weight:500;text-align:center;flex-grow:1}.photo-detail-link{color:#0b0b0f;font-size:.85rem;padding:.35rem .75rem;background:linear-gradient(140deg,hsla(0,0%,100%,.9),hsla(0,0%,100%,.7));border:1px solid hsla(0,0%,100%,.65);margin-right:.35rem}.photo-detail-link:focus,.photo-detail-link:hover{background:linear-gradient(140deg,#fff,hsla(0,0%,100%,.8));color:#0b0b0f}.close-button,.nav-button{background:hsla(0,0%,100%,.2);border:none;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;margin:0 .5rem;transition:var(--ios-transition)}.close-button:focus,.close-button:hover,.nav-button:focus,.nav-button:hover{background:hsla(0,0%,100%,.3)}.close-button:focus,.nav-button:focus{outline:2px solid #fff}.nav-button:disabled{opacity:.3;cursor:not-allowed}.photo-detail-content{flex:0 0 auto;height:240px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.photo-detail-content img{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;transition:transform .3s ease}.photo-detail-content img.zoomed{transform:scale(1.5);cursor:zoom-out}.photo-count{position:absolute;bottom:1rem;right:1rem;background:rgba(0,0,0,.6);color:#fff;padding:.3rem .6rem;border-radius:15px;font-size:.85rem}.photo-controls{padding:1rem;background-color:rgba(0,0,0,.5);display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.photo-detail-caption{color:#fff;font-size:1rem;font-weight:500}.control-hint{color:hsla(0,0%,100%,.6);font-size:.8rem}@media (max-width:1024px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (max-width:768px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}.photo-caption{padding:.4rem;font-size:.75rem}.photo-controls,.photo-detail-header{padding:.75rem}.close-button,.nav-button{width:32px;height:32px;font-size:1rem}.control-hint{display:none}}@media (max-width:600px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media (max-width:480px){.ios-photos{padding:.5rem}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(105px,1fr));gap:.4rem}.photos-header h1{font-size:1.5rem}.pagination-controls{gap:.5rem}.page-button{padding:.4rem .8rem;font-size:.8rem}.photo-detail-caption,.photo-detail-title{font-size:.9rem}}@media (max-width:360px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:.3rem}.photo-caption{font-size:.7rem;padding:.3rem}}:focus{outline:2px solid var(--ios-accent-color);outline-offset:2px}@media (max-width:767px){.photos-grid{padding-bottom:max(120px,calc(env(safe-area-inset-bottom) + 150px))!important}.ios-photos{padding-bottom:env(safe-area-inset-bottom,0)}}.photo-item.loading{background-color:rgba(0,0,0,.05)}.photo-item .hidden{opacity:0;transition:opacity .3s ease}.photo-item .visible{opacity:1;transition:opacity .3s ease}.photo-loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;border:2px solid rgba(0,0,0,.1);border-top:2px solid var(--ios-blue,#007aff);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:translate(-50%,-50%) rotate(1turn)}}.dark-mode .photo-loading-indicator{border-color:#2da337 hsla(0,0%,100%,.1) hsla(0,0%,100%,.1)}.photos-grid img{object-fit:cover;transition:transform .2s ease}.photo-detail-modal img,.photos-grid img{width:100%;height:100%;will-change:transform;transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.photo-detail-modal img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .3s ease}.photo-detail-modal img.zoomed{transform:scale(1.5);cursor:zoom-out}.photo-code-block{padding:1rem;background:rgba(0,0,0,.6);border-top:1px solid hsla(0,0%,100%,.12);color:#f7f7f7}.photo-code-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.photo-code-title{font-size:.95rem;font-weight:600}.photo-code-copy{background:hsla(0,0%,100%,.16);border:1px solid hsla(0,0%,100%,.18);color:#fff;padding:.35rem .7rem;border-radius:999px;font-size:.75rem;cursor:pointer}.photo-code-copy:focus,.photo-code-copy:hover{background:hsla(0,0%,100%,.24)}.photo-code-body{display:grid;grid-template-columns:200px minmax(0,1fr);grid-gap:12px;gap:12px;max-height:280px}.photo-code-files{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow:auto;padding-right:6px}.photo-code-file{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.12);color:hsla(0,0%,100%,.85);padding:6px 8px;border-radius:8px;text-align:left;font-size:.78rem;cursor:pointer;transition:background .12s ease,border-color .12s ease}.photo-code-file:focus,.photo-code-file:hover{background:hsla(0,0%,100%,.16);border-color:hsla(0,0%,100%,.2)}.photo-code-file.active{background:hsla(0,0%,100%,.24);border-color:hsla(0,0%,100%,.35);color:#fff}.photo-code-preview{min-width:0;max-height:280px}.photo-code-pre{margin:0;padding:.75rem;background:rgba(8,8,10,.8);border-radius:10px;overflow:auto;max-height:240px;font-size:.78rem;line-height:1.4;white-space:pre-wrap;word-break:break-word}.photo-code-empty{font-size:.85rem;color:hsla(0,0%,100%,.7)}@media (max-width:768px){.photo-code-block{padding:.75rem}.photo-detail-content{height:200px}.photo-code-body{grid-template-columns:1fr}.photo-code-files{max-height:160px;flex-direction:row;flex-wrap:wrap}.photo-code-pre{max-height:200px;font-size:.72rem}}.photo-item-no-screenshot{width:100%;height:100%;background:var(--ios-bg-secondary,#1c1c1e);display:flex;align-items:center;justify-content:center;border-radius:var(--ios-border-radius)}.photo-item-no-screenshot-inner{display:flex;flex-direction:column;align-items:center;gap:10px;color:hsla(0,0%,100%,.35);font-size:13px;font-weight:600;letter-spacing:-.01em}.photo-item-no-screenshot-inner svg{width:32px;height:32px;opacity:.4}.photo-detail-no-image{width:100%;height:240px;background:var(--ios-bg-secondary,#1c1c1e);justify-content:center;gap:14px;border-radius:10px}.photo-detail-no-image,.photo-detail-no-image-inner{display:flex;flex-direction:column;align-items:center}.photo-detail-no-image-inner{gap:10px;color:hsla(0,0%,100%,.3);font-size:18px;font-weight:700;letter-spacing:-.02em}.photo-detail-no-image-inner svg{width:48px;height:48px;opacity:.3}.photo-detail-no-image p{font-size:13px;color:hsla(0,0%,100%,.4);margin:0}.photo-detail-image{width:100%;border-radius:10px;display:block;cursor:zoom-in}.photo-detail-actions{display:flex;align-items:center;gap:8px;flex:1 1;justify-content:center}.photo-detail-link{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;text-decoration:none;transition:opacity .15s;cursor:pointer;border:none}.photo-detail-link:hover{opacity:.8}.photo-detail-link[aria-label="View on GitHub"]{background:hsla(0,0%,100%,.15);color:#fff}.photo-detail-link[aria-label="View live site"]{background:#2da337;color:#fff}.portfolio-about-body{padding:16px 0 4px;display:flex;flex-direction:column;gap:14px}.portfolio-tagline{font-size:15px;font-weight:600;color:var(--ios-text-color);margin:0;line-height:1.4}.portfolio-description{font-size:13px;color:hsla(0,0%,100%,.65);margin:0;line-height:1.6}.project-meta-badges{display:flex;align-items:center;gap:8px;margin-left:auto}.language-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.01em}.language-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.stars-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;background:rgba(255,215,0,.15);color:gold}.portfolio-stack{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.portfolio-stack-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:hsla(0,0%,100%,.4);flex-shrink:0}.portfolio-stack-tags{display:flex;flex-wrap:wrap;gap:6px}.portfolio-stack-tag{padding:3px 8px;border-radius:6px;font-size:11px;font-weight:500;background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.75);border:1px solid hsla(0,0%,100%,.12)}.portfolio-topics{display:flex;flex-wrap:wrap;gap:6px}.portfolio-topic{font-size:11px;color:rgba(45,163,55,.85);font-weight:500}