.gallery-page{background-color:#212121;min-height:100vh}.gallery-hero{text-align:center;padding:2rem 0 3rem;max-width:900px;margin:0 auto}.gallery-title{font-size:3rem;font-weight:700;color:#fff;margin:0 0 1.5rem;letter-spacing:-.02em}.gallery-subtitle{font-size:1.125rem;color:#b3b3b3;line-height:1.7;margin:0;font-weight:400}@media (max-width:768px){.gallery-title{font-size:2rem}.gallery-subtitle{font-size:1rem}}.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (min-width:640px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}@media (min-width:1024px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}}@media (min-width:1280px){.gallery-grid{grid-template-columns:repeat(4,1fr)}}.gallery-card{position:relative;background:#373737;border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;box-shadow:0 4px 20px rgba(0,0,0,.2)}.gallery-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(0,0,0,.35)}.gallery-media-container{position:relative;aspect-ratio:3/4;overflow:hidden}.gallery-media{width:100%;height:100%;object-fit:cover;transition:transform .3s ease-in-out}.gallery-card:hover .gallery-media{transform:scale(1.05)}.gallery-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.4),transparent 30%,transparent 60%,rgba(0,0,0,.7));display:flex;flex-direction:column;justify-content:space-between;padding:12px;pointer-events:none}.gallery-type-label{align-self:flex-start;padding:6px 12px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;pointer-events:auto}.type-design{background:rgba(147,51,234,.8);color:#fff;border:1px solid rgba(167,139,250,.5)}.type-model{position:relative;background:rgba(0,0,0,.6);color:#fff;border:none;backdrop-filter:blur(8px);z-index:1}.type-model:before{content:"";position:absolute;inset:-2px;border-radius:22px;padding:2px;background:linear-gradient(90deg,#f0f,#0ff,#f0f,#ff0,#0ff,#f0f);background-size:300% 100%;animation:ai-border-animation 3s linear infinite;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.type-try-on{background:rgba(59,130,246,.8);color:#fff;border:1px solid rgba(96,165,250,.5)}.type-shoot{background:rgba(34,197,94,.8);color:#fff;border:1px solid rgba(74,222,128,.5)}@keyframes ai-border-animation{0%{background-position:0 50%}to{background-position:300% 50%}}.gallery-heart-container{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;pointer-events:auto;z-index:10}.gallery-heart-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);border:1px solid hsla(0,0%,100%,.2);border-radius:50%;cursor:pointer;transition:all .2s ease}.gallery-heart-btn:hover{background:rgba(0,0,0,.7);transform:scale(1.1)}.gallery-heart-btn.loved{background:rgba(239,68,68,.9);border-color:rgba(239,68,68,.5)}.gallery-heart-btn svg{width:18px;height:18px;color:#fff;transition:transform .2s ease}.gallery-heart-btn:hover svg{transform:scale(1.1)}.gallery-heart-btn.loved svg{fill:#fff}.gallery-love-count{font-size:13px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}.gallery-hover-info{position:absolute;bottom:0;left:0;right:0;padding:16px 12px;background:linear-gradient(0deg,rgba(0,0,0,.85),transparent);opacity:0;transform:translateY(10px);transition:all .3s ease;pointer-events:none}.gallery-card:hover .gallery-hover-info{opacity:1;transform:translateY(0)}.gallery-hover-title{font-size:1rem;font-weight:600;color:#fff;margin:0 0 4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.gallery-hover-username{font-size:.85rem;color:#b3b3b3;margin:0}.gallery-hover-username:before{content:"@"}.gallery-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.gallery-tag{background:hsla(0,0%,100%,.15);color:#d1d5db;padding:3px 8px;border-radius:10px;font-size:.7rem;font-weight:500}.gallery-seo-content{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.gallery-filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:2rem}.gallery-filter-btn{padding:10px 20px;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:24px;color:#b3b3b3;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.gallery-filter-btn:hover{background:hsla(0,0%,100%,.12);color:#fff}.gallery-filter-btn.active{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.3);color:#fff}.gallery-detail-page{background-color:#212121;min-height:100vh}.gallery-detail-content{display:grid;grid-template-columns:1fr;gap:2rem;padding-top:1rem;padding-bottom:3rem}@media (min-width:1024px){.gallery-detail-content{grid-template-columns:1fr 400px;gap:3rem}}.gallery-detail-media{position:relative;border-radius:16px;overflow:hidden;background:#373737;aspect-ratio:3/4;max-height:80vh}.gallery-detail-media img,.gallery-detail-media video{width:100%;height:100%;object-fit:cover}.gallery-detail-type-label{position:absolute;top:16px;left:16px}.gallery-detail-info{display:flex;flex-direction:column;gap:1.5rem}.gallery-detail-header{display:flex;flex-direction:column;gap:.5rem}.gallery-detail-title{font-size:1.75rem;font-weight:700;color:#fff;margin:0;line-height:1.3}.gallery-detail-username{font-size:1rem;color:#9ca3af;margin:0}.gallery-detail-username a{color:#9ca3af;text-decoration:none;transition:color .2s ease}.gallery-detail-username a:hover{color:#fff}.gallery-detail-prompt-section{display:flex;flex-direction:column;gap:.75rem}.gallery-detail-label{font-size:.85rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.gallery-detail-prompt{width:100%;min-height:100px;padding:14px;background:rgba(0,0,0,.3);border:1px solid hsla(0,0%,100%,.1);border-radius:12px;color:#d1d5db;font-size:.95rem;line-height:1.6;resize:none;font-family:inherit}.gallery-detail-prompt:focus{outline:none;border-color:hsla(0,0%,100%,.2)}.gallery-recreate-btn{position:relative;display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px 24px;background:rgba(0,0,0,.6);border:none;border-radius:14px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;z-index:1;overflow:hidden}.gallery-recreate-btn:before{content:"";position:absolute;inset:-2px;border-radius:16px;padding:2px;background:linear-gradient(90deg,#f0f,#0ff,#f0f,#ff0,#0ff,#f0f);background-size:300% 100%;animation:ai-border-animation 3s linear infinite;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.gallery-recreate-btn:hover{background:rgba(0,0,0,.8);transform:translateY(-2px)}.gallery-recreate-btn svg{width:20px;height:20px}.gallery-detail-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.gallery-meta-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:rgba(0,0,0,.2);border-radius:12px}.gallery-meta-item.full-width{grid-column:1/-1}.gallery-meta-label{font-size:.75rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.gallery-meta-value{font-size:.95rem;color:#fff;word-break:break-word}.gallery-meta-value.empty{color:#6b7280;font-style:italic}.gallery-detail-tags{display:flex;flex-wrap:wrap;gap:6px}.gallery-detail-tag{background:hsla(0,0%,100%,.08);color:#d1d5db;padding:6px 12px;border-radius:12px;font-size:.8rem;font-weight:500;border:1px solid hsla(0,0%,100%,.1)}.gallery-license-section{padding:16px;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:12px}.gallery-license-text{font-size:.9rem;color:#d1d5db;line-height:1.6;margin:0}.gallery-embed-section{display:flex;flex-direction:column;gap:.75rem}.gallery-embed-container{display:flex;gap:8px}.gallery-embed-input{flex:1;padding:12px 14px;background:rgba(0,0,0,.3);border:1px solid hsla(0,0%,100%,.1);border-radius:10px;color:#9ca3af;font-size:.85rem;font-family:monospace}.gallery-embed-input:focus{outline:none;border-color:hsla(0,0%,100%,.2)}.gallery-copy-btn{display:flex;align-items:center;justify-content:center;padding:12px 16px;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:10px;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.gallery-copy-btn:hover{background:hsla(0,0%,100%,.15)}.gallery-copy-btn.copied{background:rgba(34,197,94,.2);border-color:rgba(34,197,94,.4);color:#4ade80}.gallery-back-link{display:inline-flex;align-items:center;gap:8px;color:#9ca3af;font-size:.9rem;text-decoration:none;transition:color .2s ease;margin-bottom:1rem}.gallery-back-link:hover{color:#fff}.gallery-back-link svg{width:16px;height:16px}.gallery-detail-loves{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid hsla(0,0%,100%,.1);border-bottom:1px solid hsla(0,0%,100%,.1)}.gallery-detail-heart-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:24px;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.gallery-detail-heart-btn:hover{background:hsla(0,0%,100%,.12)}.gallery-detail-heart-btn.loved{background:rgba(239,68,68,.2);border-color:rgba(239,68,68,.4)}.gallery-detail-heart-btn.loved svg{fill:#ef4444;color:#ef4444}.gallery-detail-heart-btn svg{width:18px;height:18px}