:root{--bg:#faf9f7;--text:#1a1a1a;--muted:#6b6b6b;--light:#999;--border:#e8e6e3;--font-display:'Cormorant Garamond',serif;--font-body:'Jost',sans-serif}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);font-weight:300;font-size:16px;line-height:1.7;color:var(--text);background:var(--bg);min-height:100vh;display:flex;flex-direction:column;overflow-y:hidden}
a{color:inherit;text-decoration:none;transition:opacity .3s}
a:hover{opacity:.6}
.work-link:hover{opacity:1}
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:center;align-items:center;padding:1rem;background:var(--bg)}
.symbol{width:28px;height:28px;opacity:.6;cursor:pointer;transition:opacity .3s}
.symbol:hover{opacity:1}
.main{flex:1;padding:0;margin-top:50px}
.landing-page{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);z-index:200;transition:opacity .6s ease}
.landing-symbol{width:40px;height:40px;opacity:.6;position:absolute;top:3rem;left:50%;transform:translateX(-50%)}
.landing-image{max-width:80%;max-height:70vh;width:auto;height:auto;object-fit:contain;display:block;min-height:200px}
.landing-image[src=""],.landing-image[src$="?_="]{display:none}
.landing-enter{position:absolute;bottom:4rem;left:50%;transform:translateX(-50%);padding:1rem 3rem;border:1px solid var(--text);background:transparent;color:var(--text);font-family:var(--font-body);font-size:.85rem;cursor:pointer;transition:all .3s;letter-spacing:.05em;text-transform:lowercase}
.landing-enter:hover{background:var(--text);color:var(--bg)}
.hub-page{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);z-index:150}
.hub-symbol{width:40px;height:40px;opacity:.6;position:absolute;top:3rem;left:50%;transform:translateX(-50%)}
.hub-nav{display:flex;flex-direction:column;align-items:center;gap:2rem}
.hub-nav a{font-family:var(--font-display);font-size:1.5rem;font-style:italic;color:var(--muted);text-decoration:none;transition:color .3s}
.hub-nav a:hover{color:var(--text);opacity:1}
.works{display:flex;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;height:calc(100vh - 50px);scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;opacity:0;transition:opacity .6s ease}
.works::-webkit-scrollbar{display:none}
.works.collections-view{flex-direction:column;overflow-x:hidden;overflow-y:auto;scroll-snap-type:none;align-items:center;justify-content:center;gap:2rem}
.section-note{text-align:center;font-size:0.85rem;color:var(--muted);font-style:italic;padding:0.5rem 1rem 1rem;font-family:var(--font-display);width:100%}
.work-item{min-width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;scroll-snap-align:start;padding:2rem;opacity:0;animation:fadeUp .6s ease forwards}
.collections-view .work-item{min-width:auto;height:auto;scroll-snap-align:none}
@keyframes fadeUp{to{opacity:1}}
.work-link{display:block;cursor:pointer}
.work-image{max-width:90%;max-height:calc(100vh - 200px);width:auto;height:auto;object-fit:contain;display:block;margin:0 auto 1.5rem}
.work-meta{display:flex;flex-wrap:wrap;gap:.5rem 2rem;font-size:.85rem;color:var(--muted);justify-content:center}
.work-title{font-family:var(--font-display);font-size:1.25rem;font-style:italic;color:var(--text);flex-basis:100%;text-align:center}
.work-availability.available::before{content:'';display:inline-block;width:6px;height:6px;background:#4a7c59;border-radius:50%;margin-right:.5rem;vertical-align:middle}
.collection-link{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;transition:transform .3s ease}
.collection-title{font-family:var(--font-display);font-size:1.2rem;font-style:italic;color:var(--text);text-align:center}
.collection-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;width:100%}
.collection-soon p{font-size:1.5rem;color:var(--light);font-style:italic;margin-bottom:2rem;width:100%}
.gallery-nav{position:fixed;top:50%;left:0;right:0;pointer-events:none;z-index:50}
.gallery-arrow{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--muted);font-size:2.5rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:all .3s;font-family:var(--font-body);padding:0}
.gallery-arrow:hover{color:var(--text)}
.gallery-arrow-left{left:2rem}
.gallery-arrow-right{right:2rem}
.single-work{max-width:1000px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;height:calc(100vh - 50px);justify-content:center}
.single-work img{width:100%;max-height:55vh;object-fit:contain;margin-bottom:1.5rem;cursor:pointer;position:relative}
.lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.9);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity 0.3s,visibility 0.3s}
.lightbox.active{opacity:1;visibility:visible}
.lightbox img{max-width:95%;max-height:95%;object-fit:contain}
.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;opacity:0.7;transition:opacity 0.3s}
.lightbox-close:hover{opacity:1}
.single-work-meta{display:flex;justify-content:space-between;align-items:flex-start;padding-top:1rem;border-top:1px solid var(--border);flex-shrink:0}
.single-work h1{font-family:var(--font-display);font-size:1.5rem;font-style:italic;font-weight:400;margin-bottom:.5rem}
.single-work p{font-size:.9rem;color:var(--muted)}
.back-link{display:inline-block;margin-bottom:2rem;font-size:.85rem;color:var(--muted)}
.back-link::before{content:'← '}
.inquire-btn{padding:1rem 2rem;border:1px solid var(--border);background:0 0;font-family:var(--font-body);font-size:.85rem;color:var(--muted);cursor:pointer;transition:all .3s}
.inquire-btn:hover{border-color:var(--text);color:var(--text);opacity:1}
.about{max-width:600px;margin:0 auto;padding-top:8vh;text-align:center}
.about-name{font-family:var(--font-display);font-style:italic;font-size:1.85rem;line-height:1.3;margin-bottom:2.5rem;font-weight:300}
#about-line1{font-size:1rem;line-height:1.5;margin-bottom:.5rem}
#about-line2{font-size:1rem;line-height:1.5;margin-bottom:3.5rem}
.about p:has(#about-email){margin-bottom:0}
#about-email{font-size:.8rem;color:var(--muted);transition:color .3s}
#about-email:hover{color:var(--text)}
.inquiry{max-width:500px;margin:0 auto}
.inquiry h1{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:2rem}
.work-ref{font-size:.9rem;color:var(--muted);margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.field{margin-bottom:1.5rem}
.field label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.5rem}
.field input,.field textarea{width:100%;padding:1rem;border:1px solid var(--border);background:var(--bg);font-family:var(--font-body);font-size:1rem}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--text)}
.field textarea{min-height:150px;resize:vertical}
.inquiry button{padding:1rem 3rem;border:1px solid var(--text);background:var(--text);color:var(--bg);font-family:var(--font-body);font-size:.85rem;cursor:pointer;transition:all .3s}
.inquiry button:hover{background:0 0;color:var(--text)}
.success{text-align:center;color:var(--muted);padding:3rem 0}
.footer{padding:4rem;display:flex;justify-content:center}
.footer-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.symbol-footer{display:none}
.footer-text{font-size:.8rem;color:var(--muted);margin:0}
.empty{text-align:center;padding:4rem;color:var(--light);width:100%;display:flex;align-items:center;justify-content:center}
.loading{display:flex;justify-content:center;padding:4rem}
.loading::after{content:'';width:20px;height:20px;border:1px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:768px){
    body{overflow-y:hidden}
    .landing-symbol{width:30px;height:30px;top:2rem}
    .landing-image{max-width:90%;max-height:65vh}
    .landing-enter{bottom:3rem;padding:.9rem 2.5rem;font-size:.8rem}
    .nav{padding:0.75rem 1.5rem}
    .symbol{width:24px;height:24px}
    .main{padding:0 1.5rem;margin-top:45px;margin-bottom:60px;overflow-y:auto;height:calc(100vh - 105px)}
    .footer{position:fixed;bottom:0;left:0;right:0;padding:1rem;background:var(--bg);z-index:90}
    .footer-text{font-size:.75rem}
    .about{text-align:center;padding-top:4vh}
    .section-note{font-size:0.75rem;padding:0.5rem 0 1rem}
    .works{display:block;overflow-x:visible;overflow-y:visible;scroll-snap-type:none;height:auto;max-width:100%}
    .works.collections-view{overflow-y:visible;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;height:100%;min-height:calc(100vh - 105px)}
    .works.collections-view .work-item{height:auto;min-height:auto;margin-bottom:0}
    .works.collection-artworks-view{display:flex;height:calc(100vh - 140px);position:relative}
    .works.collection-artworks-view .work-item{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:1rem 1.5rem;margin:0}
    .work-item{min-width:auto;height:auto;margin-bottom:6rem;padding:0}
    .work-link{display:block;width:auto;height:auto}
    .work-image{max-width:100%;max-height:none;width:100%;height:auto;margin-bottom:1rem}
    .works.collection-artworks-view .work-image{max-width:100%;max-height:60vh;width:auto;height:auto;object-fit:contain;margin:0 auto 1.5rem}
    .work-meta{flex-direction:column;gap:.4rem;justify-content:center;align-items:center;font-size:.75rem}
    .work-title{text-align:center;font-size:1rem;margin-bottom:0}
    .works.collection-artworks-view .work-meta{gap:.5rem;align-items:center;text-align:center;justify-content:center}
    .works.collection-artworks-view .work-title{margin-bottom:0;text-align:center}
    .collection-title{opacity:1;font-size:1rem}
    .collection-soon{min-height:50vh}
    .single-work{height:auto;padding:1.5rem 0}
    .single-work img{cursor:pointer}
    .single-work-meta{flex-direction:column;gap:1.5rem}
    .inquire-btn{width:100%;text-align:center}
    .gallery-arrow{font-size:2rem;width:40px;height:40px}
    .gallery-arrow-left{left:0.5rem}
    .gallery-arrow-right{right:0.5rem}
}
