 * {
     font-family: 'Inter', sans-serif;
 }

 body {
     background: #ffffff;
     color: #111;
     overflow-x: hidden;
 }


 #google_translate_element {
     display: none;
 }

 .goog-te-banner-frame,
 .skiptranslate {
     display: none !important;
 }

 body {
     top: 0 !important;
 }


 .lang-btn {
     display: inline-flex;
     align-items: center;
     gap: 5px;
     font-size: 11px;
     font-weight: 700;
     letter-spacing: 0.05em;
     padding: 5px 11px;
     border-radius: 999px;
     border: 1.5px solid #d1d5db;
     background: #fff;
     color: #374151;
     cursor: pointer;
     transition: border-color .2s, background .2s, color .2s, transform .15s;
     user-select: none;
 }

 .lang-btn:hover {
     border-color: #111;
     background: #f9fafb;
     transform: translateY(-1px);
 }

 .lang-btn .lang-flag {
     font-size: 14px;
     line-height: 1;
 }

 .lang-btn .lang-label {
     transition: opacity .15s;
 }

 .lang-btn.translating .lang-label {
     opacity: 0.5;
 }


 .sa {
     opacity: 0;
     transform: translateY(20px);
     transition: opacity .6s ease, transform .6s ease;
 }

 .sa.vis {
     opacity: 1;
     transform: translateY(0);
 }


 @keyframes skeleton-loading {
     0% {
         background-color: #f3f4f6;
     }

     50% {
         background-color: #e5e7eb;
     }

     100% {
         background-color: #f3f4f6;
     }
 }

 .skeleton {
     animation: skeleton-loading 1.5s infinite ease-in-out;
 }

 .skeleton-text {
     border-radius: 4px;
 }

 .skeleton-img {
     border-radius: 12px;
 }


 .section-label {
     font-size: 11px;
     font-weight: 700;
     letter-spacing: .12em;
     text-transform: uppercase;
     color: #6b7280;
 }


 .hero-bg {
     background: linear-gradient(180deg, #f9f9fb 0%, #ffffff 100%);
     border-bottom: 1px solid #f3f4f6;
 }


 .filter-chip {
     padding: 6px 14px;
     border-radius: 999px;
     font-size: 13px;
     font-weight: 600;
     color: #6b7280;
     border: 1px solid #e5e7eb;
     transition: all .2s;
     cursor: pointer;
     background: transparent;
 }

 .filter-chip:hover {
     border-color: #d1d5db;
     color: #111;
 }

 .filter-chip.active {
     background: #111;
     color: #fff;
     border-color: #111;
 }


 .view-btn {
     width: 32px;
     height: 32px;
     border-radius: 8px;
     display: flex;
     align-items: center;
     justify-content: center;
     color: #9ca3af;
     transition: all .2s;
 }

 .view-btn:hover {
     color: #111;
     background: #f3f4f6;
 }

 .view-btn.active {
     color: #111;
     background: #f3f4f6;
 }


 .masonry {
     columns: 4;
     column-gap: 16px;
 }

 @media (max-width: 1280px) {
     .masonry {
         columns: 3;
     }
 }

 @media (max-width: 768px) {
     .masonry {
         columns: 2;
     }
 }

 .photo-item {
     break-inside: avoid;
     margin-bottom: 16px;
     border-radius: 16px;
     overflow: hidden;
     border: 1px solid #e5e7eb;
     background: #f9f9fb;
     cursor: zoom-in;
     transition: border-color .25s, box-shadow .25s, transform .25s;
 }

 .photo-item:hover {
     border-color: #c9c9c9;
     box-shadow: 0 8px 32px rgba(0, 0, 0, .08);
     transform: translateY(-3px);
 }

 .photo-item img {
     width: 100%;
     display: block;
     transition: transform .4s ease;
 }

 .photo-item:hover img {
     transform: scale(1.03);
 }

 .photo-item .photo-meta {
     padding: 12px 14px;
     border-top: 1px solid #f3f4f6;
 }


 .badge-featured {
     display: inline-flex;
     align-items: center;
     gap: 3px;
     font-size: 10px;
     font-weight: 700;
     color: #92400e;
     background: #fef3c7;
     border: 1px solid #fde68a;
     padding: 2px 8px;
     border-radius: 999px;
 }


 .num-badge {
     display: inline-block;
     font-size: 10px;
     font-weight: 800;
     color: #111;
     background: #f3f4f6;
     padding: 2px 6px;
     border-radius: 4px;
     margin-bottom: 4px;
 }


 .mobile-card {
     border: 1px solid #e5e7eb;
     border-radius: 14px;
     overflow: hidden;
     background: #fff;
 }


 .bottom-nav {
     position: fixed;
     bottom: 0;
     left: 0;
     right: 0;
     background: rgba(255, 255, 255, 0.95);
     backdrop-filter: blur(10px);
     border-top: 1px solid #e5e7eb;
     z-index: 50;
     padding-bottom: env(safe-area-inset-bottom);
 }


 .back-btn {
     display: inline-flex;
     align-items: center;
     gap: 6px;
     font-size: 13px;
     font-weight: 600;
     color: #374151;
     text-decoration: none;
     padding: 6px 0;
     transition: color .2s;
 }

 .back-btn:hover {
     color: #111;
 }


 .lb-overlay {
     position: fixed;
     inset: 0;
     z-index: 1000;
     background: rgba(0, 0, 0, .88);
     backdrop-filter: blur(12px);
     display: flex;
     align-items: center;
     justify-content: center;
     opacity: 0;
     pointer-events: none;
     transition: opacity .25s;
 }

 .lb-overlay.open {
     opacity: 1;
     pointer-events: all;
 }

 .lb-img {
     max-width: 90vw;
     max-height: 85vh;
     object-fit: contain;
     border-radius: 12px;
     box-shadow: 0 32px 80px rgba(0, 0, 0, .5);
     transition: opacity .2s;
 }

 .lb-btn {
     position: fixed;
     width: 44px;
     height: 44px;
     border-radius: 50%;
     background: rgba(255, 255, 255, .12);
     border: 1px solid rgba(255, 255, 255, .2);
     color: #fff;
     font-size: 1rem;
     display: flex;
     align-items: center;
     justify-content: center;
     cursor: pointer;
     transition: background .2s;
 }

 .lb-btn:hover {
     background: rgba(255, 255, 255, .22);
 }

 .lb-close {
     top: 20px;
     right: 24px;
 }

 .lb-prev {
     top: 50%;
     left: 20px;
     transform: translateY(-50%);
 }

 .lb-next {
     top: 50%;
     right: 20px;
     transform: translateY(-50%);
 }

 .lb-meta {
     position: fixed;
     bottom: 28px;
     left: 50%;
     transform: translateX(-50%);
     text-align: center;
     white-space: nowrap;
 }

 .lb-meta h3 {
     font-size: .9rem;
     font-weight: 700;
     color: #fff;
 }

 .lb-meta p {
     font-size: .8rem;
     color: rgba(255, 255, 255, .55);
     margin-top: 3px;
 }