/* 4870 Studios — design system. Boxes, big type, serif accents. Matches book.4870studios.com.au. */
:root{
  --bg:#0a0a0a; --box:#101012; --box-2:#141417; --line:rgba(255,255,255,.09); --line-hi:rgba(255,255,255,.28);
  --text:#f5f6f7; --muted:#9298a0; --accent:#a78bfa; --ink:#0f0a19;
  --max:1220px; --sans:'Lato',system-ui,sans-serif; --serif:'Fraunces',Georgia,serif;
  --r:26px; --r-lg:34px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden;-webkit-text-size-adjust:100%;color-scheme:dark}
body{background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased}
body.lock{overflow:hidden}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%;height:auto}
::selection{background:var(--accent);color:var(--ink)}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
h1,h2,h3{font-weight:700;line-height:1;letter-spacing:-.02em}
.serif{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.14em;line-height:1;text-transform:none;letter-spacing:-.02em;color:transparent;background:linear-gradient(110deg,#a78bfa 0%,#a78bfa 46%,#e6ddff 50%,#a78bfa 54%,#a78bfa 100%);background-size:250% 100%;-webkit-background-clip:text;background-clip:text;animation:serifshine 7s linear infinite}
@keyframes serifshine{from{background-position:100% 0}to{background-position:0% 0}}
@media (prefers-reduced-motion:reduce){.serif{animation:none;background:none;color:var(--accent)}}
.index{font-size:12px;font-weight:900;letter-spacing:.18em;color:var(--accent);text-transform:uppercase}
.muted{color:var(--muted)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:900;font-size:15px;padding:14px 28px;border-radius:100px;transition:transform .2s,filter .2s,border-color .2s,background .2s,color .2s;white-space:nowrap;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--accent);color:var(--ink)}
.btn-primary:hover{background:#c4b5fd}
.btn-outline{background:rgba(255,255,255,.05);border-color:var(--line-hi);color:var(--text)}
.btn-outline:hover{background:var(--accent);border-color:var(--accent);color:var(--ink)}
.btn-sm{padding:11px 20px;font-size:14px}
.btn:active{transform:scale(.98)}
.btnrow{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}

/* NAV — floating pill bar */
header{position:fixed;top:0;left:0;right:0;z-index:60;padding:16px 24px 0;transition:padding .3s}
.navbar{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;height:64px;padding:0 12px 0 24px;border-radius:100px;border:1px solid var(--line);background:rgba(16,16,18,.5);backdrop-filter:blur(18px);transition:background .3s,border-color .3s}
header.scrolled .navbar{background:rgba(16,16,18,.86);border-color:rgba(255,255,255,.1)}
.brand img{height:24px;width:auto;display:block}
.links{display:flex;gap:4px}
.links a{font-size:16px;line-height:24px;font-weight:700;color:var(--muted);padding:10px 17px;border:1px solid transparent;border-radius:100px;transition:color .25s,background-color .25s}
.links a:hover{color:var(--text);background:rgba(255,255,255,.08)}
.links a.on,.mnav a.on{color:var(--accent)}
.nav-right{display:flex;align-items:center;gap:8px}
.menu-btn{display:none;background:rgba(255,255,255,.06);border:1px solid var(--line-hi);color:#fff;width:44px;height:44px;border-radius:100px;font-size:17px;cursor:pointer;align-items:center;justify-content:center}
.mob-only{display:none}

/* mobile menu */
.mnav{position:fixed;left:0;right:0;top:0;z-index:55;background:rgba(10,10,10,.98);backdrop-filter:blur(22px);border-bottom:1px solid var(--line);display:flex;flex-direction:column;padding:98px 24px 36px;gap:2px;transform:translateY(-100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);visibility:hidden}
.mnav.open{transform:none;visibility:visible}
.mnav a{padding:17px 4px;font-size:1.5rem;font-weight:900;letter-spacing:-.02em;border-bottom:1px solid var(--line);color:var(--text)}
.mnav a.btn{margin-top:20px;border-bottom:0;font-size:15px}

/* HERO */
.hero{position:relative;min-height:70svh;overflow:hidden}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero .veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,10,10,.45),rgba(10,10,10,.1) 34%,rgba(10,10,10,.82) 80%,#0a0a0a 100%)}
/* the studios stack (heading + boxes) overlaps the lower video; the heading sits
   over the video and the podcast box peeks above the fold with the same gap as the boxes */
#studios{position:relative;z-index:2;margin-top:-24vh;padding-top:0}
.shead{text-align:center}
.shead .index{margin-bottom:16px}
.shead h1,.shead h2{font-size:clamp(2.4rem,7vw,6.2rem);line-height:.98;letter-spacing:-.03em;text-shadow:0 2px 40px rgba(0,0,0,.4)}

section{padding:clamp(72px,9vw,120px) 0;position:relative}
.head{max-width:900px}
.head h2{font-size:clamp(2.2rem,5.5vw,4.6rem);margin-top:14px}
.head p{margin-top:20px;color:var(--muted);font-size:1.1rem;max-width:58ch;font-weight:400}

/* STUDIO boxes */
.stack{display:flex;flex-direction:column;gap:52px}
/* two compact studio cards side by side over the hero video */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.studio2{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--box);padding:16px;transition:border-color .3s,background .3s}
.studio2:hover{border-color:rgba(167,139,250,.4);background:var(--box-2)}
.studio2 .media{aspect-ratio:16/10}
.studio2:hover .media img{transform:scale(1.05)}
.studio2 .body{padding:22px 12px 10px;display:flex;flex-direction:column;flex:1}
.studio2 h3{font-size:clamp(1.5rem,2.2vw,2.1rem);margin:12px 0 12px;line-height:1.08}
.studio2 .body p{color:var(--muted);font-weight:400;max-width:52ch;flex:1}
.studio2 .btnrow{margin-top:24px}
.studio{display:grid;grid-template-columns:1.05fr 1fr;gap:44px;align-items:center;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--box);padding:22px;transition:border-color .3s,background .3s}
.studio:hover{border-color:rgba(167,139,250,.4);background:var(--box-2)}
.studio.rev .media{order:2}
.media{position:relative;border-radius:calc(var(--r-lg) - 12px);overflow:hidden;aspect-ratio:4/3}
.media img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.studio:hover .media img{transform:scale(1.05)}
.studio .body{padding:16px 22px}
.studio h3{font-size:clamp(1.9rem,3.6vw,3.2rem);margin:14px 0 16px;line-height:1.02}
.studio .body p{color:var(--muted);max-width:46ch;font-weight:400}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin:22px 0 28px}
.tags span{font-size:12.5px;font-weight:700;color:#cdd2d6;border:1px solid var(--line);padding:8px 15px;border-radius:100px}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:14px;margin-top:52px}
.gallery a{position:relative;overflow:hidden;border-radius:var(--r);border:1px solid var(--line);transition:border-color .3s}
.gallery a:hover{border-color:rgba(167,139,250,.5)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.gallery a:hover img{transform:scale(1.07)}
.gallery .tall{grid-row:span 2}.gallery .wide{grid-column:span 2}
.gallery a{cursor:zoom-in}

/* VIDEO showcase */
.vidgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px}
.vid{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);cursor:pointer;aspect-ratio:16/9;transition:border-color .3s}
.vid:hover{border-color:rgba(167,139,250,.55)}
.vid img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.vid:hover img{transform:scale(1.06)}
.vid .play{position:absolute;inset:0;display:grid;place-items:center;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.55))}
.vid .play span{width:62px;height:62px;border-radius:100px;background:rgba(167,139,250,.94);color:var(--ink);display:grid;place-items:center;font-size:20px;padding-left:4px;transition:transform .3s}
.vid:hover .play span{transform:scale(1.12)}
.vid .t{position:absolute;left:18px;right:18px;bottom:15px;z-index:2;font-weight:900;text-transform:uppercase;font-size:.92rem;letter-spacing:-.01em;text-shadow:0 2px 10px rgba(0,0,0,.6)}

/* LIGHTBOX */
.lb{position:fixed;inset:0;z-index:100;background:rgba(6,6,7,.94);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;padding:24px}
.lb.open{display:flex;animation:lbfade .25s ease}
@keyframes lbfade{from{opacity:0}to{opacity:1}}
.lb-x{position:absolute;top:20px;right:24px;width:48px;height:48px;border-radius:100px;border:1px solid var(--line-hi);background:rgba(255,255,255,.06);color:#fff;font-size:19px;cursor:pointer;z-index:2;transition:.2s}
.lb-x:hover{border-color:var(--accent);color:var(--accent)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:100px;border:1px solid var(--line-hi);background:rgba(255,255,255,.06);color:#fff;font-size:19px;cursor:pointer;z-index:2;display:none;align-items:center;justify-content:center;transition:border-color .25s,color .25s,background-color .25s}
.lb-nav:hover{border-color:var(--accent);color:var(--accent)}
.lb-prev{left:22px}.lb-next{right:22px}
.lb-count{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:none;font-size:12px;font-weight:800;letter-spacing:.18em;color:#9aa0a6}
.lb.gal .lb-nav{display:flex}
.lb.gal .lb-count{display:block}
@media (max-width:700px){.lb-nav{width:44px;height:44px}.lb-prev{left:8px}.lb-next{right:8px}}
.lb-inner{max-width:min(1120px,95vw);width:100%;display:flex;align-items:center;justify-content:center}
.lb-inner img{max-width:100%;max-height:86vh;border-radius:14px;object-fit:contain}
.lb-inner .vwrap{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;background:#000}
.lb-inner iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* click-to-play video facades (no third-party JS until tapped) */
.vfac{cursor:pointer}
.vfac img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vfac .playbtn{position:absolute;inset:0;display:grid;place-items:center;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.4));border:0;cursor:pointer}
.vfac .playbtn span{width:60px;height:60px;border-radius:100px;background:rgba(167,139,250,.95);color:#06131a;display:grid;place-items:center;font-size:19px;padding-left:3px;transition:transform .3s}
.vfac:hover .playbtn span{transform:scale(1.1)}

/* direct video embeds (true aspect ratio) */
.embed{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:#000}
.embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.r169{padding-top:56.25%}
.r916{aspect-ratio:9/16}
.vfeature{margin-top:52px}
.vgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:14px}

/* SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:52px}
.svc{border:1px solid var(--line);border-radius:var(--r);padding:34px;background:var(--box);transition:border-color .3s,transform .3s,background .3s}
.svc:hover{border-color:rgba(167,139,250,.55);background:var(--box-2)}
.svc .ic{width:50px;height:50px;border-radius:15px;background:rgba(167,139,250,.13);display:grid;place-items:center;color:var(--accent);margin-bottom:22px}
.svc .ic svg{width:25px;height:25px}
.svc h3{font-size:1.4rem;margin-bottom:10px}
.svc p{color:var(--muted);font-size:.97rem;font-weight:400}

/* FAQ — heading left, questions right, both snapped to the container edges */
.faqgrid{display:grid;grid-template-columns:1fr 1.7fr;gap:clamp(28px,5vw,72px);align-items:start}
.faqgrid .head p a{color:var(--accent);font-weight:700}
.faqgrid .head p a:hover{text-decoration:underline;text-underline-offset:3px}
.faq{margin:0}
.faq details{border:1px solid var(--line);border-radius:var(--r);background:var(--box);margin-bottom:12px;overflow:hidden;transition:border-color .3s}
.faq details[open]{border-color:rgba(167,139,250,.4)}
.faq summary{list-style:none;cursor:pointer;padding:24px 28px;font-weight:900;font-size:1.1rem;display:flex;justify-content:space-between;gap:16px;letter-spacing:-.01em;transition:color .2s}
.faq summary:hover{color:var(--accent)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:1.5rem;line-height:1;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 28px 26px;color:var(--muted);font-weight:400;overflow:hidden;transition:max-height .4s cubic-bezier(.33,0,.2,1),opacity .32s ease,padding-bottom .4s cubic-bezier(.33,0,.2,1)}
.faq .a a:not(.btn){color:var(--accent);font-weight:700}
.faq .a a:not(.btn):hover{text-decoration:underline;text-underline-offset:3px}
.faq .a .btn{margin-top:16px}

/* GIFT CARD band */
.gift{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;border:1px solid var(--line);border-radius:var(--r-lg);background:radial-gradient(120% 160% at 100% 0%,rgba(167,139,250,.14),transparent 55%),var(--box);padding:clamp(22px,3vw,36px) clamp(22px,3vw,36px) clamp(22px,3vw,36px) clamp(34px,5vw,64px)}
.gift h2{font-size:clamp(2rem,4.4vw,3.6rem)}
.gift p{color:var(--muted);margin-top:18px;max-width:52ch;font-weight:400}
.gift .btn{margin-top:28px}
.gift .gimg{border-radius:calc(var(--r-lg) - 12px);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/11}
.gift .gimg img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.gift:hover .gimg img{transform:scale(1.04)}

/* CTA */
.cta-bg::before{content:"";position:absolute;inset:0;background:url(/assets/entrance.webp) center/cover;opacity:.13;pointer-events:none}
.cta-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 150% at 50% 0%,rgba(10,10,10,.1),rgba(10,10,10,.55));pointer-events:none}
.cta-bg>*{position:relative;z-index:1}
.cta{border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(48px,7vw,88px) 32px;text-align:center;overflow:hidden;position:relative;background:radial-gradient(120% 150% at 50% 0%,rgba(167,139,250,.16),transparent 58%),var(--box)}
.cta h2{font-size:clamp(2.4rem,6vw,5rem)}
.cta p{color:var(--muted);margin:20px auto 34px;max-width:50ch;font-weight:400;font-size:1.06rem}

/* FOOTER — matches book.4870studios.com.au */
footer{border-top:1px solid var(--line);background:#0d0d0f}
.footcopy{max-width:var(--max);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:20px;padding:46px 24px;text-align:center;color:#6b7176;font-size:.82rem;line-height:1.7}
.footcopy p a{color:#8b9096;text-decoration:underline;text-underline-offset:2px;transition:color .2s}
.footcopy p a:hover{color:var(--text)}
.footlinks a{color:#8b9096;margin:0 6px;transition:color .2s}
.footlinks a:hover{color:var(--text)}
.poweredby{display:flex;flex-direction:column;align-items:center;gap:7px;opacity:.6;transition:opacity .2s}
.poweredby:hover{opacity:1}
.poweredby span{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#6b7176;font-weight:700}
.poweredby img{height:24px;width:auto}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* every hover state animates smoothly — colour and border changes, no movement */
.studio,.studio2,.vid,.svc,.post,.price,.cblock,.gallery a,.faq details{transition:border-color .35s ease,background-color .35s ease}

/* spacing continuity: one consistent gap between a small label and its heading, everywhere */
.index+h2,.index+h3,.eyebrow+h2,.eyebrow+h3{margin-top:14px}

/* interior pages */
.hero-sm{padding:150px 0 60px;background:radial-gradient(80% 130% at 12% 0%,rgba(167,139,250,.1),transparent 55%)}
.hero-sm h1{font-size:clamp(2.5rem,6vw,5rem);line-height:.98}
.hero-sm.article h1{text-transform:none;font-size:clamp(1.9rem,4vw,3.3rem);max-width:24ch;letter-spacing:-.02em;line-height:1.02}
.hero-sm.article .wrap{max-width:var(--max)}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:12px}
.post{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--box);transition:.3s;display:flex;flex-direction:column}
.post:hover{border-color:rgba(167,139,250,.55);background:var(--box-2)}
.post .thumb{aspect-ratio:16/10;overflow:hidden}
.post .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.post .thumb img.klapfit{object-fit:contain;background:#0d0e1d}
.post:hover .thumb img{transform:scale(1.05)}
.post .pad{padding:26px;display:flex;flex-direction:column;flex:1}
.post .cat{font-size:11px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.post h3{font-size:1.3rem;margin:12px 0 8px;line-height:1.15;text-transform:none;letter-spacing:-.02em}
.post p{color:var(--muted);font-size:.95rem;flex:1;font-weight:400}
.prose{max-width:none;margin:0;font-size:1.12rem;line-height:1.7;color:#d3d7db;font-weight:400}
.prose>p,.prose h2{max-width:none}
.prose>p:first-of-type{font-size:1.3rem;line-height:1.62;color:#e7e9eb;margin-bottom:28px}
.prose h2{position:relative;font-size:1.55rem;text-transform:none;letter-spacing:-.01em;margin:48px 0 16px;padding-top:18px;color:var(--text);line-height:1.2}
.prose h2::before{content:"";position:absolute;top:0;left:0;width:34px;height:3px;background:var(--accent);border-radius:2px}
.prose p{margin:0 0 24px}
.prose strong{color:var(--text);font-weight:700}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;transition:color .2s}
.prose a:hover{color:#aacbdc}
.prose .backlink{display:inline-block;margin-top:14px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;text-decoration:none}
.meta{color:var(--muted);font-size:.88rem;margin-top:16px;text-transform:uppercase;letter-spacing:.14em;font-weight:800}
.postfeat{margin:12px 0 0;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9}
.postfeat img{width:100%;height:100%;object-fit:cover}
.postfeat img.klapfit{object-fit:contain;background:#0d0e1d}
/* article layout — meta rail left, readable text column right */
.artgrid{display:grid;grid-template-columns:minmax(210px,.9fr) 2.5fr;gap:clamp(28px,5vw,72px);align-items:start;margin-top:clamp(36px,5vw,56px)}
.artmeta{position:sticky;top:110px;border:1px solid var(--line);border-radius:var(--r);background:var(--box);padding:26px}
.artmeta .am{margin-bottom:20px}
.artmeta .k{font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:4px}
.artmeta .v{font-weight:700;font-size:.98rem}
.artmeta .btn{margin-top:4px}
/* studio page hero image */
.pagehero{margin:0;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9}
.pagehero img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.pagehero:hover img{transform:scale(1.03)}

/* interior page building blocks */
.crumbs{display:flex;gap:9px;align-items:center;font-size:12px;font-weight:800;color:var(--muted);margin-bottom:20px;text-transform:uppercase;letter-spacing:.14em}
.crumbs a{color:var(--accent)}
.hero-sm .eyebrow{margin-bottom:16px}
.eyebrow{font-size:12px;font-weight:900;letter-spacing:.18em;color:var(--accent);text-transform:uppercase}
.lead{font-size:clamp(1.12rem,1.9vw,1.4rem);color:#cbd0d5;font-weight:400;max-width:62ch;line-height:1.55;margin-top:22px}
/* alternating feature rows */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:40px}
.feat+.feat{margin-top:64px}
.feat .fimg{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3}
.feat .fimg img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.feat:hover .fimg img{transform:scale(1.04)}
.feat.rev .fimg{order:2}
.feat h2{font-size:clamp(1.9rem,3.4vw,2.9rem);margin-bottom:16px}
.feat p{color:var(--muted);font-weight:400;max-width:50ch}
.feat p+p{margin-top:16px}
/* inclusions chips */
.incl{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.incl span{font-size:13px;font-weight:700;color:#cdd2d6;border:1px solid var(--line);background:var(--box);padding:12px 19px;border-radius:100px}
/* pricing */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:36px;max-width:720px}
.pricecol .price-grid{margin-top:0;max-width:none}
.price-grid:has(> .price:only-child){grid-template-columns:1fr}
.price-grid.cols3{grid-template-columns:repeat(3,1fr)}
.note a{color:var(--accent);font-weight:700}
.note a:hover{text-decoration:underline;text-underline-offset:3px}
.pricecol .addons{max-width:none}
.savetag{display:inline-block;background:rgba(167,139,250,.15);color:#a78bfa;font-weight:800;font-size:.72rem;padding:2px 9px;border-radius:999px;vertical-align:1px}
.pricecol .note{max-width:none}
.price{border:1px solid var(--line);border-radius:var(--r);background:var(--box);padding:34px;transition:border-color .3s,background .3s}
.price:hover{border-color:rgba(167,139,250,.5);background:var(--box-2)}
.price .plan{font-size:12px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.price .amt{font-size:clamp(2.4rem,5vw,3.4rem);font-weight:900;margin:10px 0 2px;letter-spacing:-.03em;line-height:1}
.price .per{color:var(--muted);font-size:.95rem}
.addons{margin-top:16px;max-width:720px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--box)}
.addons .row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:17px 24px;border-bottom:1px solid var(--line);font-size:1rem;font-weight:700}
.addons .row small{display:block;color:var(--muted);font-weight:400;font-size:.85rem;margin-top:3px}
.addons .row:last-child{border-bottom:0}
.addons .row span:last-child{color:var(--accent);white-space:nowrap}
.note{color:var(--muted);font-size:.9rem;margin-top:16px;max-width:60ch;font-weight:400}
@media (max-width:700px){.note{text-align:center;margin-inline:auto}}
.kitbox{margin-top:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--box);padding:20px 24px 24px;transition:border-color .35s ease,background-color .35s ease}
.kitbox:hover{border-color:rgba(167,139,250,.5)}
.kitbox .khead{display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:1rem;font-weight:700;padding:4px 4px 0}
.kitbox .khead small{display:block;color:var(--muted);font-weight:400;font-size:.85rem;margin-top:3px}
.kitbox .khead span:last-child{color:var(--accent);white-space:nowrap}
.kit-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.kit{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:calc(var(--r) - 8px);background:var(--box-2);padding:24px;transition:border-color .35s ease,background-color .35s ease}
.kit:hover{border-color:rgba(167,139,250,.5)}
.kit .klabel{font-size:12px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.kit h3{font-size:1.3rem;margin:10px 0 8px}
.kit p{color:var(--muted);font-weight:400;font-size:.95rem}
.kit .kfit{margin-top:auto;padding-top:14px;color:#cdd2d6;font-weight:700;font-size:.85rem}

/* contact page */
.cblocks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
.cblock{display:block;border:1px solid var(--line);border-radius:var(--r);background:var(--box);padding:28px;transition:border-color .3s,background .3s}
a.cblock:hover{background:var(--box-2)}
.cblock:hover{border-color:rgba(167,139,250,.5)}
a.cblock{display:flex;align-items:center;gap:16px}
.cblock .ic{width:44px;height:44px;border-radius:13px;background:rgba(167,139,250,.13);display:grid;place-items:center;color:var(--accent);flex-shrink:0}
.cblock .ic svg{width:21px;height:21px}
.cblock .k{font-size:12px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:4px}
.cblock a,.cblock p{color:var(--text);font-weight:700;font-size:1.02rem;line-height:1.4}
.cblock a:hover{color:var(--accent)}
.cmap{margin-top:20px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/6}
.cmap iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.4) invert(.92) hue-rotate(175deg) contrast(.9)}
.form{max-width:640px;margin-top:14px;display:grid;gap:15px}
.faqgrid .form{max-width:none;margin-top:0}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea{background:var(--box);border:1px solid var(--line);border-radius:14px;padding:14px 16px;color:var(--text);font-family:inherit;font-size:1rem;transition:border-color .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{min-height:140px;resize:vertical}

@media(max-width:900px){
  .links,.desk-only{display:none}
  .menu-btn,.mob-only{display:inline-flex}
  .navbar{height:58px;padding:0 12px 0 20px}
  .mob-only.btn-sm{padding:10px 16px}
  #studios{margin-top:-22vh}
  .stack{gap:32px}
  .shead h1,.shead h2{font-size:clamp(1.9rem,8vw,3.2rem)}
  .studio{grid-template-columns:1fr;gap:16px;padding:16px}
  .studio.rev .media{order:0}.studio .body{padding:8px 8px 14px}
  .svc-grid,.post-grid,.vidgrid,.vgrid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  section{padding:64px 0}.head p{font-size:1rem}
  .feat{grid-template-columns:1fr;gap:24px}.feat.rev .fimg{order:0}.feat+.feat{margin-top:44px}
  .price-grid{grid-template-columns:1fr 1fr}
  .price-grid.cols3{grid-template-columns:1fr 1fr}
  .kit-grid{grid-template-columns:1fr}
  .hero-sm{padding:130px 0 48px}
  .cblocks{grid-template-columns:1fr}
  .faqgrid{grid-template-columns:1fr;gap:16px}
  .duo{grid-template-columns:1fr}
  .gift{grid-template-columns:1fr;padding:18px 18px 18px 18px}
  .gift>div:first-child{padding:14px 8px 22px}
  .gift .btn{width:100%}
  .artgrid{grid-template-columns:1fr;gap:26px}
  .artmeta{position:static;display:flex;flex-wrap:wrap;align-items:center;gap:4px 34px;padding:20px 22px}
  .artmeta .am{margin:0}
  .artmeta .btn{margin:6px 0 0}
}
@media(max-width:560px){
  .price-grid.cols3{grid-template-columns:1fr}
  .wrap{padding:0 18px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%}
  .svc-grid,.post-grid,.vidgrid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:130px}
  .gallery .wide{grid-column:span 2}.gallery .tall{grid-row:span 1}
  .svc{padding:26px}.cta{padding:44px 20px}
  .faq summary{padding:20px 20px;font-size:1rem}.faq .a{padding:0 20px 22px}
}

/* respect reduced-motion preferences */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  *,*::before,*::after{animation:none!important;transition:none!important}
}

.brandsec{padding-top:8px}
.brandlabel{text-align:center}
.brands{overflow:hidden;position:relative;margin-top:30px}
.brands::before,.brands::after{content:"";position:absolute;top:0;bottom:0;width:13%;z-index:1;pointer-events:none}
.brands::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.brands::after{right:0;background:linear-gradient(270deg,var(--bg),transparent)}
.brands .track{display:flex;flex-wrap:nowrap;width:max-content;transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden;animation:brandscroll 30s linear infinite}
.brands img{display:block;flex:0 0 auto;height:74px;width:auto}
@media (max-width:700px){
  .brands .track{animation-duration:16s}
  .brands img{height:50px}
}
@keyframes brandscroll{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.brands .track{animation:none}}

.kit .krow{display:flex;align-items:center;justify-content:space-between;gap:12px}
.kit .klogo{height:16px;width:auto;filter:brightness(0) invert(.6);opacity:.9}

.mapduo{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:26px}
.mapduo .cmap,.mapduo .duoimg{height:440px;aspect-ratio:auto;min-width:0;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);margin:0}
.mapduo .cmap iframe{width:100%;height:100%;border:0;display:block}
.mapduo .duoimg img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:820px){.mapduo{grid-template-columns:1fr}.mapduo .cmap,.mapduo .duoimg{height:320px}}
