:root {
  --c-bg:#0d0d0d;--c-card:#161616;--c-alt:#111;--c-border:#2a2a2a;
  --c-text:#e8e0d4;--c-dim:#8a8278;--c-bright:#fff;
  --c-gold:#c9a96e;--c-gold-hi:#dfc08a;--c-gold-soft:#2a2418;
  --r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-pill:999px;
  --sh-sm:0 4px 12px rgba(0,0,0,.3);--sh-md:0 12px 30px rgba(0,0,0,.5);
  --trans:.2s ease;
  --font-d:'Playfair Display',Georgia,serif;
  --font-b:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth;overflow-x:hidden}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}}
body{margin:0;font-family:var(--font-b);color:var(--c-text);background:var(--c-bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--c-gold);text-decoration:none}a:hover{text-decoration:underline}
img,svg,video{max-width:100%}
h1,h2,h3,h4{font-family:var(--font-d);font-weight:800;color:var(--c-bright);line-height:1.1;margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:clamp(2.8rem,6vw,4.5rem)}h2{font-size:clamp(1.8rem,3.5vw,2.6rem)}h3{font-size:1.2rem;font-family:var(--font-b);font-weight:700}
p{margin:0 0 1em}.container{max-width:1140px;margin:0 auto;padding:0 20px}
.skip-link{position:absolute;left:-9999px;top:0;z-index:999;background:var(--c-gold);color:var(--c-bg);padding:10px 16px;border-radius:0 0 var(--r-md) 0;font-weight:700}.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--c-gold);outline-offset:3px;border-radius:4px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:var(--r-pill);font-weight:700;font-size:.95rem;border:2px solid transparent;cursor:pointer;transition:transform var(--trans),box-shadow var(--trans),background var(--trans);text-decoration:none!important;white-space:nowrap;font-family:var(--font-b)}
.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}
.btn-gold{background:var(--c-gold);color:var(--c-bg);box-shadow:0 6px 20px rgba(201,169,110,.35)}.btn-gold:hover{background:var(--c-gold-hi)}
.btn-outline-light{background:transparent;color:var(--c-bright);border-color:rgba(255,255,255,.3)}.btn-outline-light:hover{background:rgba(255,255,255,.08)}
.btn-sm{padding:10px 18px;font-size:.88rem}.btn-lg{padding:16px 28px;font-size:1rem}.btn-xl{padding:20px 36px;font-size:1.15rem}.btn-block{display:flex;width:100%}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(13,13,13,.92);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--c-border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 20px}
.brand{display:inline-flex;align-items:center;gap:12px;text-decoration:none!important}
.brand-icon{width:40px;height:40px;border-radius:50%;background:var(--c-gold);color:var(--c-bg);font-family:var(--font-d);font-weight:900;font-size:1rem;display:inline-flex;align-items:center;justify-content:center}
.brand-logo{width:56px;height:56px;border-radius:8px;display:block;object-fit:cover;flex-shrink:0;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.brand-logo-footer{width:48px;height:48px}
@media(max-width:480px){.brand-logo{width:46px;height:46px;border-radius:6px}}
.brand-text strong{display:block;font-size:1.05rem;color:var(--c-bright);line-height:1.1}.brand-text small{display:block;font-size:.72rem;color:var(--c-dim);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
.nav{display:flex;gap:24px}.nav a{color:var(--c-text);font-weight:500;font-size:.92rem;transition:color var(--trans);padding:4px 0}.nav a:hover{color:var(--c-gold);text-decoration:none}
.header-actions{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:36px;height:36px;position:relative;padding:0}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--c-bright);position:absolute;left:7px;transition:all .25s ease}
.nav-toggle span:nth-child(1){top:10px}.nav-toggle span:nth-child(2){top:17px}.nav-toggle span:nth-child(3){top:24px}
.nav-toggle.is-open span:nth-child(1){top:17px;transform:rotate(45deg)}.nav-toggle.is-open span:nth-child(2){opacity:0}.nav-toggle.is-open span:nth-child(3){top:17px;transform:rotate(-45deg)}
@media(max-width:880px){.nav{display:none}.nav-toggle{display:block}.header-actions .btn{display:none}}
.mobile-nav{position:fixed;inset:0;top:65px;z-index:49;background:rgba(13,13,13,.97);backdrop-filter:blur(12px);display:flex;align-items:flex-start;justify-content:center;padding:40px 24px;overflow-y:auto}
.mobile-nav nav{display:flex;flex-direction:column;gap:8px;width:100%;max-width:400px}
.mobile-nav a{display:block;padding:16px 20px;font-size:1.1rem;font-weight:600;color:var(--c-bright);border-radius:var(--r-md);transition:background var(--trans);text-decoration:none}.mobile-nav a:hover{background:var(--c-card)}.mobile-nav .btn{margin-top:12px}

/* Hero */
.hero{position:relative;padding:80px 0 100px;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-1;background:radial-gradient(ellipse at 50% 0%,rgba(201,169,110,.18),transparent 65%),radial-gradient(ellipse at 20% 80%,rgba(100,60,20,.12),transparent 50%),var(--c-bg)}
.hero-inner{max-width:820px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.hero-art{width:100%;max-width:540px;height:auto;display:block;margin:0 auto 28px;border-radius:14px;box-shadow:0 24px 64px rgba(0,0,0,.65),0 0 0 1px rgba(201,169,110,.12);background:#0a0a0a}
.hero h1{margin-bottom:8px}
.hero-title{font-size:1.3rem;color:var(--c-gold);font-weight:600;margin-bottom:16px;letter-spacing:.02em}
.hero-sub{font-size:1.1rem;color:var(--c-dim);max-width:640px;margin:0 auto 32px;line-height:1.6}
.hero-sub a{color:var(--c-gold);font-weight:600}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:780px){.hero{padding:48px 0 72px}.hero-art{max-width:88vw;margin-bottom:22px;border-radius:10px}}
@media(max-width:600px){.hero-cta .btn{flex:1 1 100%}}

/* Sections */
.section{padding:90px 0}.section-alt{background:var(--c-alt)}
.section-head{text-align:center;max-width:680px;margin:0 auto 50px}.section-head p{color:var(--c-dim);font-size:1.05rem}
.eyebrow{display:inline-block;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--c-gold);margin-bottom:12px;font-family:var(--font-b)}
.section-cta{text-align:center;margin-top:36px;color:var(--c-dim);font-size:.95rem}
@media(max-width:760px){.section{padding:64px 0}}
@media(max-width:480px){.section{padding:50px 0}.section-head{margin-bottom:36px}}

/* About */
.about-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:50px;align-items:start}
.about-copy p{color:var(--c-dim);font-size:1.02rem}
.style-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.tag{display:inline-block;padding:6px 14px;background:var(--c-gold-soft);border:1px solid rgba(201,169,110,.3);border-radius:var(--r-pill);font-size:.82rem;font-weight:600;color:var(--c-gold)}
.about-card{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:32px}
.about-card h3{color:var(--c-gold);margin-bottom:18px}
.info-list{margin:0 0 10px}.info-list dt{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--c-dim);margin-bottom:2px}
.info-list dd{margin:0 0 14px;padding:0;color:var(--c-bright);font-size:.95rem}.info-list dd a{color:var(--c-gold)}
@media(max-width:820px){.about-grid{grid-template-columns:1fr}}

/* Portfolio / Gallery */
/* Portfolio gallery — masonry-style: natural aspect ratios, no cropping, responsive columns */
.gallery{column-count:4;column-gap:14px;margin-top:8px}
@media(max-width:1140px){.gallery{column-count:3}}
@media(max-width:780px){.gallery{column-count:2;column-gap:10px}}
@media(max-width:380px){.gallery{column-count:1}}

.gallery-item{position:relative;border-radius:var(--r-md);overflow:hidden;background:var(--c-card);border:1px solid var(--c-border);transition:transform var(--trans),border-color var(--trans),box-shadow var(--trans);
  break-inside:avoid;-webkit-column-break-inside:avoid;page-break-inside:avoid;
  display:block;margin:0 0 14px;width:100%}
@media(max-width:780px){.gallery-item{margin-bottom:10px}}
.gallery-item:hover{transform:translateY(-3px);border-color:var(--c-gold);box-shadow:0 12px 32px rgba(0,0,0,.45)}
.gallery-item img{width:100%;height:auto;display:block;aspect-ratio:auto}
.gallery-item .img-caption{padding:11px 13px;color:var(--c-dim);font-size:.8rem;line-height:1.45;border-top:1px solid var(--c-border)}
@media(max-width:480px){.gallery-item .img-caption{padding:9px 11px;font-size:.74rem;line-height:1.4}}
.gallery-item .img-keywords{padding:4px 14px 10px;display:flex;flex-wrap:wrap;gap:4px}
.gallery-item .img-keyword{display:inline-block;padding:2px 8px;background:var(--c-gold-soft);border-radius:var(--r-pill);font-size:.7rem;color:var(--c-gold);font-weight:600}
.gallery-item .img-remove{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:rgba(200,40,40,.9);color:#fff;border:2px solid #fff;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:.9rem;padding:0;box-shadow:var(--sh-sm)}
body.edit-mode .gallery-item .img-remove{display:inline-flex}

.gallery-empty{margin-top:20px}
.gallery-empty{display:none}
body.edit-mode .gallery-empty{display:block!important}
.upload-zone{border:2px dashed var(--c-border);border-radius:var(--r-xl);padding:60px 30px;text-align:center;transition:border-color var(--trans),background var(--trans);cursor:pointer}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--c-gold);background:var(--c-gold-soft)}
.upload-zone svg{color:var(--c-dim);margin-bottom:12px}
.upload-zone h3{margin-bottom:6px;color:var(--c-bright)}.upload-zone p{color:var(--c-dim);font-size:.9rem;margin-bottom:16px}

/* Shops */
.shops-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.shop-card{position:relative;border-radius:var(--r-xl);overflow:hidden;padding:32px 24px;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;text-decoration:none!important;border:1px solid var(--c-border);transition:transform var(--trans),border-color var(--trans)}
.shop-card:hover{transform:translateY(-4px);border-color:var(--c-gold)}
.shop-card-bg{position:absolute;inset:0;z-index:-1}
.shop-badge{display:inline-block;padding:4px 12px;background:var(--c-gold);color:var(--c-bg);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;border-radius:var(--r-pill);margin-bottom:12px;align-self:flex-start}
.shop-card h3{color:var(--c-bright);margin-bottom:4px;font-size:1.3rem}
.shop-loc{color:var(--c-gold);font-size:.85rem;font-weight:600;margin-bottom:8px}
.shop-card p{color:var(--c-dim);font-size:.9rem;line-height:1.5}
.shop-link{display:inline-block;margin-top:12px;color:var(--c-gold);font-weight:700;font-size:.9rem}
@media(max-width:900px){.shops-grid{grid-template-columns:1fr}}

/* Artists */
.artists-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.artist-card{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-xl);overflow:hidden;transition:transform var(--trans),border-color var(--trans)}
.artist-card:hover{transform:translateY(-3px);border-color:var(--c-gold)}
.artist-img{height:180px}
.artist-img-link{display:block;height:180px;overflow:hidden}
.artist-photo{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--trans)}
.artist-card:hover .artist-photo{transform:scale(1.04)}
.artist-ig{display:block;padding:0 16px 14px;font-size:.78rem;font-weight:600;color:var(--c-gold);opacity:.7;transition:opacity var(--trans)}
.artist-ig:hover{opacity:1;text-decoration:none}

/* Artist edit controls (visible only in edit mode) */
.artist-edit-panel{display:none;padding:10px 16px 14px;border-top:1px dashed var(--c-border)}
body.edit-mode .artist-edit-panel{display:block}
.artist-edit-panel label{display:block;margin-bottom:8px}
.artist-edit-panel label span{display:block;font-size:.7rem;font-weight:700;color:var(--c-gold);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.artist-edit-panel input{width:100%;padding:7px 10px;border:1px solid var(--c-border);border-radius:var(--r-sm);background:var(--c-bg);color:var(--c-bright);font-size:.82rem;font-family:var(--font-b)}
.artist-edit-panel input:focus{outline:none;border-color:var(--c-gold)}
.artist-edit-panel .btn{margin-top:6px;font-size:.78rem;padding:6px 12px}
.ae-photo-drop{padding:14px;border:2px dashed var(--c-border);border-radius:var(--r-sm);text-align:center;font-size:.8rem;color:var(--c-dim);cursor:pointer;transition:border-color var(--trans),background var(--trans)}
.ae-photo-drop:hover{border-color:var(--c-gold);background:var(--c-gold-soft)}
.artist-card h3{padding:14px 16px 2px;margin:0;font-size:1rem}
.artist-meta{padding:0 16px;margin:0 0 4px;font-size:.82rem;color:var(--c-gold);font-weight:500}
.artist-shop{padding:0 16px 14px;margin:0;font-size:.78rem;color:var(--c-dim)}
.artist-shop a{color:var(--c-dim);font-weight:600}.artist-shop a:hover{color:var(--c-gold)}
@media(max-width:980px){.artists-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.artists-grid{grid-template-columns:1fr}.artist-img{height:160px}}

/* CTA */
.cta-section{padding:100px 0;text-align:center;background:radial-gradient(ellipse at 50% 0%,rgba(201,169,110,.15),transparent 55%),var(--c-bg)}
.cta-inner h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:10px}
.cta-inner>p{color:var(--c-dim);font-size:1.15rem;margin-bottom:30px}
.cta-alt{display:flex;gap:16px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:24px;font-size:.95rem}.cta-alt span{color:var(--c-border)}

/* Footer */
.site-footer{background:#080808;padding:60px 0 0}
.footer-inner{display:grid;grid-template-columns:1.3fr 2fr;gap:50px;padding-bottom:40px}
.footer-brand{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.footer-brand strong{display:block;color:var(--c-bright);font-size:1rem}.footer-brand small{display:block;color:var(--c-dim);font-size:.82rem;margin-top:2px}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.footer-cols h4{font-family:var(--font-b);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--c-gold);margin-bottom:14px}
.footer-cols ul{list-style:none;padding:0;margin:0}.footer-cols li{margin-bottom:8px;font-size:.92rem;color:var(--c-dim)}
.footer-cols a{color:var(--c-dim);transition:color var(--trans)}.footer-cols a:hover{color:var(--c-gold);text-decoration:none}
.sub-footer{border-top:1px solid var(--c-border);padding:20px 0;color:var(--c-dim);font-size:.82rem}
.sub-footer-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
@media(max-width:760px){.footer-inner{grid-template-columns:1fr}.footer-cols{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.footer-cols{grid-template-columns:1fr}}

/* Admin */
.admin-link{background:transparent;border:none;color:var(--c-dim);font-size:.8rem;cursor:pointer;padding:8px 14px;border-radius:var(--r-sm);font-family:inherit;min-height:36px;transition:color var(--trans)}.admin-link:hover{color:var(--c-gold)}
.admin-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}
.admin-backdrop{position:absolute;inset:0;background:rgba(6,6,6,.8);backdrop-filter:blur(4px)}
.admin-box{position:relative;background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:32px 28px;width:100%;max-width:380px;box-shadow:var(--sh-md)}
.admin-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:none;background:var(--c-bg);color:var(--c-dim);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}.admin-close:hover{color:var(--c-bright)}
.admin-box h3{color:var(--c-bright);margin-bottom:18px}
.admin-box label span{display:block;font-size:.82rem;font-weight:700;color:var(--c-dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.admin-box input{width:100%;padding:12px;border:1px solid var(--c-border);border-radius:var(--r-sm);font-size:1rem;margin-bottom:14px;background:var(--c-bg);color:var(--c-bright);font-family:inherit}
.admin-box input:focus{outline:none;border-color:var(--c-gold);box-shadow:0 0 0 3px rgba(201,169,110,.18)}
.admin-err{color:#e44;font-size:.88rem;margin:-6px 0 10px;font-weight:600}

/* Edit bar */
.edit-bar{position:fixed;top:0;left:0;right:0;z-index:150;background:var(--c-gold);color:var(--c-bg);box-shadow:var(--sh-md)}
.edit-bar-inner{max-width:1140px;margin:0 auto;padding:10px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.edit-label{font-size:.88rem}.edit-actions{display:flex;gap:8px;flex-wrap:wrap}
body.edit-mode{padding-top:56px}
body.edit-mode [contenteditable="true"]{outline:1px dashed rgba(201,169,110,.55);outline-offset:2px;cursor:text;transition:outline var(--trans),background var(--trans)}
body.edit-mode [contenteditable="true"]:hover{background:rgba(201,169,110,.06);outline-color:var(--c-gold)}
body.edit-mode [contenteditable="true"]:focus{outline:2px solid var(--c-gold);background:rgba(201,169,110,.1)}
@media(max-width:680px){.edit-bar-inner{padding:10px 14px;gap:8px}.edit-label{font-size:.82rem;width:100%}.edit-actions{width:100%}body.edit-mode{padding-top:110px}}

/* Sticky mobile CTA */
.sticky-cta{display:none;position:fixed;left:16px;right:16px;bottom:16px;background:var(--c-gold);color:var(--c-bg);font-weight:800;padding:16px 20px;border-radius:var(--r-pill);text-align:center;z-index:100;box-shadow:0 12px 36px rgba(201,169,110,.45);text-decoration:none!important;align-items:center;justify-content:center;gap:10px}
.sticky-cta:hover{background:var(--c-gold-hi)}
@media(max-width:700px){.sticky-cta{display:inline-flex;right:80px}.cta-section{padding-bottom:120px}.site-footer{padding-bottom:90px}}

/* Booking Bubble */
.booking-widget{position:fixed;right:20px;bottom:20px;z-index:110}
.booking-bubble{width:60px;height:60px;border-radius:50%;background:var(--c-gold);color:var(--c-bg);border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(201,169,110,.4);transition:transform var(--trans);padding:0}
.booking-bubble:hover{transform:scale(1.08)}
.booking-bubble .bk-close{display:none}
.booking-widget.is-open .booking-bubble .bk-open{display:none}
.booking-widget.is-open .booking-bubble .bk-close{display:inline-block}
.booking-widget.is-open .booking-bubble{background:var(--c-card);border:1px solid var(--c-border);color:var(--c-bright);box-shadow:var(--sh-md)}
.booking-panel{position:absolute;right:0;bottom:74px;width:370px;max-width:calc(100vw - 32px);max-height:calc(100vh - 110px);background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-xl);box-shadow:var(--sh-md);overflow:hidden;display:flex;flex-direction:column;animation:bkSlide .22s ease-out}
@keyframes bkSlide{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.booking-head{padding:18px 22px;background:var(--c-gold-soft);border-bottom:1px solid var(--c-border)}
.booking-head strong{display:block;color:var(--c-bright);font-size:1.05rem}
.booking-head small{color:var(--c-dim);font-size:.8rem}
.booking-form{padding:14px 20px 20px;overflow-y:auto;flex:1}
.booking-form label{display:block;margin-bottom:10px}
.booking-form label>span{display:block;font-size:.75rem;font-weight:700;color:var(--c-gold);margin-bottom:3px;text-transform:uppercase;letter-spacing:.04em}
.booking-form input,.booking-form select{width:100%;padding:9px 11px;border:1px solid var(--c-border);border-radius:var(--r-sm);font-family:var(--font-b);font-size:.9rem;color:var(--c-bright);background:var(--c-bg)}
.booking-form input:focus,.booking-form select:focus{outline:none;border-color:var(--c-gold);box-shadow:0 0 0 3px rgba(201,169,110,.15)}
.booking-form .btn{margin-top:8px}
.booking-note{font-size:.75rem;color:var(--c-dim);text-align:center;margin:8px 0 0}
.booking-success{padding:32px 24px;text-align:center}
.success-icon{width:48px;height:48px;margin:0 auto 12px;border-radius:50%;background:var(--c-gold);color:var(--c-bg);font-size:1.5rem;display:flex;align-items:center;justify-content:center;font-weight:700}
.booking-success h4{color:var(--c-bright);margin-bottom:6px}
.booking-success p{color:var(--c-dim);font-size:.9rem;margin-bottom:16px}
@media(max-width:700px){.booking-widget{right:16px;bottom:16px}.booking-bubble{width:56px;height:56px}.booking-panel{width:calc(100vw - 24px);right:-8px;bottom:68px}}

/* Style picker modal (image upload SEO tagging) */
.style-picker-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.8);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px}
.style-picker-box{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:32px;width:100%;max-width:440px;max-height:calc(100vh - 40px);overflow-y:auto;box-shadow:var(--sh-md)}
.style-picker-box h3{margin-bottom:8px;color:var(--c-bright)}
.style-picker-box label{display:block;margin-bottom:14px}
.style-picker-box label>span{display:block;font-size:.78rem;font-weight:700;color:var(--c-gold);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}
.style-picker-box input,.style-picker-box select{width:100%;padding:10px 12px;border:1px solid var(--c-border);border-radius:var(--r-sm);font-family:var(--font-b);font-size:.92rem;color:var(--c-bright);background:var(--c-bg)}
.style-picker-box input:focus,.style-picker-box select:focus{outline:none;border-color:var(--c-gold);box-shadow:0 0 0 3px rgba(201,169,110,.15)}

/* Primary style card */
.style-card-primary{border-color:var(--c-gold);box-shadow:0 0 30px rgba(201,169,110,.15)}
.style-card-primary:hover{box-shadow:0 0 40px rgba(201,169,110,.25)}

/* Directions list */
.directions-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.directions-list li .btn{justify-content:space-between}

/* Two-column layout */
.two-col{display:grid;grid-template-columns:1.4fr 1fr;gap:50px;align-items:start}
.col-text p{color:var(--c-dim);font-size:1.02rem}
.col-card{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:30px}
.col-card h3{color:var(--c-gold);margin-bottom:16px}
@media(max-width:820px){.two-col{grid-template-columns:1fr}}

/* Map embed */
.map-embed iframe{width:100%;border-radius:var(--r-lg)}

/* Blog grid */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.blog-card{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:28px;transition:transform var(--trans),border-color var(--trans)}
.blog-card:hover{transform:translateY(-3px);border-color:var(--c-gold)}
.blog-card h3{font-size:1.05rem;margin-bottom:10px;color:var(--c-bright);font-family:var(--font-b)}
.blog-excerpt{font-size:.88rem;color:var(--c-dim);line-height:1.6;margin-bottom:12px}
.blog-meta{font-size:.78rem;color:var(--c-gold);font-weight:600}
@media(max-width:900px){.blog-grid{grid-template-columns:1fr}}

/* Style label badge on cards */
.style-label{display:inline-block;padding:3px 10px;background:var(--c-gold-soft);border:1px solid rgba(201,169,110,.3);border-radius:var(--r-pill);font-size:.72rem;font-weight:700;color:var(--c-gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}

/* Shop address line */
.shop-addr{font-size:.82rem;color:var(--c-dim);margin-bottom:8px;font-style:italic}

/* CTA buttons row */
.cta-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Footer 4-column */
.footer-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:820px){.footer-cols{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.footer-cols{grid-template-columns:1fr}}

/* Reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* === Affiliated Artists === */
.affiliated-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; margin-top: 24px; }
.affiliated-card { display: block; text-decoration: none; color: inherit; background: var(--card-bg, rgba(255,255,255,0.04)); border: 1px solid var(--border, rgba(255,255,255,0.08)); border-radius: 8px; overflow: hidden; transition: transform 0.2s, border-color 0.2s; }
.affiliated-card:hover { transform: translateY(-3px); border-color: var(--accent, #e8c560); }
.affiliated-card picture { display: block; aspect-ratio: 1/1; overflow: hidden; }
.affiliated-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
.affiliated-body { padding: 14px 16px; }
.affiliated-body h3 { margin: 0 0 4px; font-size: 16px; font-weight: 700; }
.aff-specialty { margin: 0 0 4px; font-size: 12px; opacity: 0.85; }
.aff-shop { margin: 0; font-size: 11px; opacity: 0.6; text-transform: uppercase; letter-spacing: 0.5px; }

/* MARKER:IMG-SIZE-FIX */
/* === Image sizing — preserve natural aspect ratio, never stretch === */
.gallery-item img, .gallery-item picture { display: block; width: 100%; height: auto; aspect-ratio: auto; object-fit: contain; }
figure.gallery-item picture { line-height: 0; }


/* ═══════════════════════════════════════════════════════════════════
   MARKER:UNIVERSAL-MOBILE-FIX — 2026-05-13
   Network-wide mobile safety. Stops header-CTA overflow, makes hero
   text wrap, stacks CTA pairs on narrow viewports.
   ═══════════════════════════════════════════════════════════════════ */

/* Global overflow safety */
html, body { overflow-x: hidden !important; max-width: 100vw; }
img, picture, video, svg, iframe { max-width: 100%; }

@media (max-width: 720px) {
  /* Header CTA hides on phones — sticky bottom bar / hamburger handles bookings */
  .header-cta, .header-actions .btn, .header-cta-wrap, .header-actions .header-cta,
  .site-header .btn, .site-header a.btn,
  a.btn.header-cta, a.btn-gold.btn-sm.header-cta { display: none !important; }

  /* Ensure brand text in header doesn't get pushed off */
  .site-header .container, .header-row, .header-inner { flex-wrap: wrap; gap: 8px; }
  .brand, .brand-text { min-width: 0; }
  .brand-text strong, .brand-text small { overflow: hidden; text-overflow: ellipsis; }

  /* Eyebrow + headlines wrap properly */
  .eyebrow { white-space: normal !important; word-wrap: break-word; overflow-wrap: anywhere; }
  h1, h2, h3, .hero-name, .hero-wordmark, .hero-title, .hero-tag {
    overflow-wrap: anywhere; word-break: normal; max-width: 100%;
  }
  .hero, .hero-inner, .hero-content, .hero-bg, .article-hero,
  .container, .container-narrow { max-width: 100% !important; box-sizing: border-box; }
  .container, .container-narrow { padding-left: 16px; padding-right: 16px; }

  /* Hero CTA pair stacks vertically on narrow viewports */
  .hero-ctas, .hero-meta, .hero-cta { flex-direction: column !important; align-items: stretch !important; }
  .hero-ctas .btn, .hero-meta .btn, .hero-cta .btn { width: 100% !important; min-width: 0 !important; }

  /* Trust pills wrap nicely */
  .hero-trust { flex-wrap: wrap !important; justify-content: center !important; gap: 8px 12px !important; }
  .hero-trust li { white-space: nowrap; }

  /* Card grids never wider than viewport */
  .cards-grid, .grid, .styles-grid, .gallery, .network-grid, .scout-grid {
    max-width: 100% !important; box-sizing: border-box;
  }

  /* Intake form fits */
  .intake-form { width: 100% !important; max-width: 100% !important; box-sizing: border-box; }
  .intake-form select, .intake-form input, .intake-form button { min-width: 0; max-width: 100%; box-sizing: border-box; }

  /* WORD-BREAK-PASS-2 */
  /* Tighter word-break for unbreakable strings (URLs, "Photoreal", etc.) */
  .hero-tag, .hero-name, .hero-name-accent, .hero-wordmark,
  .article-hero h1, .feature h1, h1, h2, p {
    hyphens: auto;
    -webkit-hyphens: auto;
    overflow-wrap: anywhere !important;
  }
  /* Last-resort safety: prevent any element from forcing horizontal scroll */
  body * { max-width: 100vw; }

}
/* ═══════════════════════════════════════════════════════════════════ */

/* === Scroll logo brand mark — networked (2026-05-20) === */
.brand-mark-img {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: #fff;
  padding: 4px;
  object-fit: contain;
  box-shadow: 0 2px 12px rgba(0,0,0,0.4);
  flex-shrink: 0;
}


/* ═══════════════════════════════════════════════════════════════════
   TG AESTHETIC RESTYLE (2026-05-20)
   Modeled directly on the new TG hero + circular logo:
   antique gold + aged bronze + oxblood maroon + black + warm cream highlight.
   Baroque filigree, Asian-traditional dragon/tiger energy, engraved feel.
   ═══════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=UnifrakturCook:wght@700&family=Playfair+Display:ital,wght@1,400;0,700&display=swap');

:root {
  --c-bg:        #0E0805;
  --c-card:      #1A100A;
  --c-alt:       #15090A;
  --c-border:    rgba(201, 169, 110, 0.18);
  --c-border-hi: rgba(212, 178, 108, 0.42);
  --c-text:      #E8D4A8;
  --c-dim:       #A8916F;
  --c-bright:    #F5E8C8;

  /* Antique gold spectrum from the hero */
  --c-gold:        #C9A35E;
  --c-gold-hi:     #E2C173;
  --c-gold-deep:   #8B6914;
  --c-gold-soft:   #2D2010;
  --c-bronze:      #6B4E1A;
  --c-bronze-deep: #3B2E1F;

  /* Oxblood maroon from the dragon scales + banners */
  --c-oxblood:    #5C1A14;
  --c-oxblood-hi: #8B2A22;

  --c-aged-paper: #E8D4A8;
}

body {
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(201,163,94,0.16), transparent 65%),
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(92,26,20,0.18), transparent 70%),
    radial-gradient(ellipse 50% 40% at 10% 30%, rgba(107,78,26,0.12), transparent 60%),
    var(--c-bg) !important;
  color: var(--c-text);
}

/* Typography — Cinzel for headings (engraved), Playfair italic for accents */
h1, h2, h3, h4, .h1, .h2, .h3 {
  font-family: 'Cinzel', 'Playfair Display', serif !important;
  letter-spacing: 0.01em !important;
  color: var(--c-bright) !important;
}
h1 {
  font-family: 'Cinzel', serif !important;
  font-weight: 900 !important;
  text-shadow: 0 2px 0 var(--c-bronze-deep), 0 4px 18px rgba(201,163,94,0.35);
}
h2 {
  font-weight: 700 !important;
  color: var(--c-gold-hi) !important;
}
h2::after {
  content: '';
  display: block;
  width: 90px;
  height: 2px;
  margin: 14px auto 0;
  background: linear-gradient(90deg, transparent, var(--c-gold), transparent);
}
.section-head, .section-head-centered {
  text-align: center;
}
.eyebrow {
  font-family: 'Cinzel', serif !important;
  font-weight: 600 !important;
  color: var(--c-gold) !important;
  letter-spacing: 0.18em !important;
  font-size: .78rem !important;
  border: 1px solid rgba(201,163,94,0.4);
  padding: 6px 18px;
  border-radius: 2px;
  background: linear-gradient(180deg, rgba(201,163,94,0.08), rgba(107,78,26,0.04));
}

/* Header — engraved bronze frame */
.site-header {
  background: rgba(14,8,5,0.94) !important;
  backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid rgba(201,163,94,0.22) !important;
  box-shadow: 0 1px 0 rgba(212,178,108,0.08), 0 6px 32px rgba(0,0,0,0.5);
}
.brand-logo {
  filter: drop-shadow(0 2px 6px rgba(201,163,94,0.3));
}
.brand-text strong {
  font-family: 'Cinzel', serif !important;
  color: var(--c-gold-hi) !important;
}
.brand-text small {
  color: var(--c-dim) !important;
}
.nav a {
  font-family: 'Cinzel', serif !important;
  font-weight: 600 !important;
  font-size: .85rem !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-text) !important;
}
.nav a:hover {
  color: var(--c-gold-hi) !important;
}

/* Buttons — gold-on-black with bronze edge + inner glow */
.btn {
  font-family: 'Cinzel', serif !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: .85rem !important;
  border-radius: 2px !important;
  border: 1px solid transparent;
  position: relative;
  transition: transform 0.2s ease, box-shadow 0.3s ease;
}
.btn-gold, .btn-primary {
  background: linear-gradient(180deg, var(--c-gold-hi), var(--c-gold-deep)) !important;
  color: var(--c-bg) !important;
  border: 1px solid var(--c-bronze) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.3),
    inset 0 -1px 0 rgba(0,0,0,0.25),
    0 4px 14px rgba(201,163,94,0.35) !important;
}
.btn-gold:hover, .btn-primary:hover {
  background: linear-gradient(180deg, #F0CE83, var(--c-gold)) !important;
  transform: translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.4),
    0 6px 22px rgba(201,163,94,0.5) !important;
}
.btn-outline, .btn-outline-light {
  background: transparent !important;
  color: var(--c-gold-hi) !important;
  border: 1px solid var(--c-gold) !important;
}
.btn-outline:hover, .btn-outline-light:hover {
  background: rgba(201,163,94,0.1) !important;
  color: var(--c-bright) !important;
}

/* Section dividers — ornate gold filigree */
.section-alt {
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%, rgba(107,78,26,0.15), transparent 70%),
    var(--c-alt) !important;
  position: relative;
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
}
.section-alt::before {
  content: '';
  display: block;
  width: 200px;
  height: 22px;
  margin: 0 auto 56px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 22'%3E%3Cpath d='M0 11 H75 M125 11 H200' stroke='%23C9A35E' stroke-width='1' fill='none' opacity='0.55'/%3E%3Cpath d='M100 4 L106 8 L100 18 L94 8 Z' fill='%23C9A35E' opacity='0.7'/%3E%3Cpath d='M70 11 Q75 4 80 11 Q85 18 90 11' stroke='%23C9A35E' stroke-width='1' fill='none' opacity='0.5'/%3E%3Cpath d='M110 11 Q115 4 120 11 Q125 18 130 11' stroke='%23C9A35E' stroke-width='1' fill='none' opacity='0.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}

/* Cards + portfolio — engraved gold frame */
.card, .col-card, .gallery-item {
  background: linear-gradient(180deg, rgba(26,16,10,0.7), var(--c-card)) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 4px !important;
  transition: border-color 0.3s, box-shadow 0.3s, transform 0.3s;
}
.card:hover, .gallery-item:hover {
  border-color: var(--c-gold) !important;
  box-shadow:
    0 0 0 1px var(--c-gold-deep) inset,
    0 12px 32px rgba(0,0,0,0.5),
    0 0 24px rgba(201,163,94,0.18) !important;
  transform: translateY(-2px);
}
.gallery-item img {
  transition: filter 0.4s, transform 0.4s;
  filter: contrast(1.05) saturate(0.95);
}
.gallery-item:hover img {
  filter: contrast(1.12) saturate(1.05);
  transform: scale(1.02);
}

/* Style chips — sharp engraved gold pills */
.style-chip {
  font-family: 'Cinzel', serif !important;
  font-size: .7rem !important;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-gold-hi) !important;
  background: rgba(107,78,26,0.18) !important;
  border: 1px solid var(--c-gold) !important;
  border-radius: 2px !important;
  padding: 5px 12px !important;
}

/* Info list (Quick Facts) */
.info-list dt, .footer-cols h4 {
  font-family: 'Cinzel', serif !important;
  color: var(--c-gold) !important;
  letter-spacing: 0.12em !important;
  font-size: .72rem !important;
}
.info-list dd {
  color: var(--c-text) !important;
}
.info-list dd a {
  color: var(--c-gold-hi) !important;
}

/* Hero text below image */
.hero h1 {
  font-family: 'Cinzel', serif !important;
  font-weight: 900 !important;
  font-size: clamp(2.4rem, 5vw, 4rem) !important;
  color: var(--c-gold-hi) !important;
}
.hero-title {
  font-family: 'Playfair Display', serif !important;
  font-style: italic;
  color: var(--c-gold) !important;
}
.hero-sub {
  color: var(--c-text) !important;
}
.hero-sub a {
  color: var(--c-gold-hi) !important;
  border-bottom: 1px solid rgba(201,163,94,0.4);
}

/* Footer — aged scroll */
.site-footer {
  background:
    radial-gradient(ellipse 100% 50% at 50% 0%, rgba(107,78,26,0.1), transparent 70%),
    var(--c-bg) !important;
  border-top: 1px solid var(--c-border);
  padding-top: 60px;
}
.site-footer .brand-text strong {
  color: var(--c-gold-hi) !important;
}

/* FAQ */
.faq-item, details.faq-item {
  border: 1px solid var(--c-border);
  border-radius: 4px;
  background: linear-gradient(180deg, rgba(26,16,10,0.6), transparent);
  margin-bottom: 12px;
}
.faq-item summary, details.faq-item summary {
  color: var(--c-gold-hi) !important;
  font-family: 'Cinzel', serif !important;
  font-weight: 600;
  padding: 16px 20px;
}

/* Links throughout */
a {
  color: var(--c-gold-hi);
}
a:hover {
  color: var(--c-bright);
}

/* Hero stat trust list — engraved gold checkmarks */
.hero-trust li, .stats-bar li {
  color: var(--c-gold) !important;
  font-family: 'Cinzel', serif !important;
  font-size: .8rem !important;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.hero-trust li svg {
  color: var(--c-gold-hi) !important;
}

/* Mobile nav — same antique gold */
.mobile-nav {
  background: rgba(14,8,5,0.97) !important;
}
.mobile-nav a {
  color: var(--c-text) !important;
  font-family: 'Cinzel', serif !important;
}
.mobile-nav a:hover {
  background: rgba(201,163,94,0.1) !important;
  color: var(--c-gold-hi) !important;
}

/* Tags / pill labels */
.tag, .pill, .chip {
  font-family: 'Cinzel', serif !important;
  background: rgba(107,78,26,0.2) !important;
  color: var(--c-gold-hi) !important;
  border: 1px solid var(--c-gold-deep) !important;
}

/* Section padding breathing room */
.section { padding: 90px 0 !important; }
@media (max-width: 720px) {
  .section { padding: 56px 0 !important; }
}

/* Hero trust list — kill default bullets, use only the SVG checkmarks */
.hero-trust {
  list-style: none !important;
  padding: 0 !important;
  margin: 24px auto 0 !important;
  display: flex !important;
  flex-wrap: wrap;
  gap: 12px 28px;
  justify-content: center;
  max-width: 720px;
}
.hero-trust li {
  list-style: none !important;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.hero-trust li::marker { content: '' !important; }
