 :root{--cream:#fff5e8;--ink:#11110f;--orange:#ff6b00;--pink:#ff3a8c;--lav:#b99bea;--sage:#8d9d64;--lime:#c7d300;--soft:#f7e7f1;--line:rgba(17,17,15,.16);--shadow:0 26px 70px rgba(17,17,15,.16)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--cream);color:var(--ink);font-family:Inter,Arial,sans-serif}body:before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.16;background-image:linear-gradient(45deg,rgba(255,58,140,.16) 25%,transparent 25%),linear-gradient(-45deg,rgba(255,58,140,.12) 25%,transparent 25%);background-size:42px 42px}h1,h2,h3,.serif{font-family:Fraunces,Georgia,serif}.hand{font-family:"Amatic SC",cursive}.top{background:var(--pink);color:#fff;text-align:center;font-weight:900;letter-spacing:.12em;text-transform:uppercase;padding:.65rem;display:flex;align-items:center;justify-content:center;gap:.7rem;flex-wrap:wrap}.top-contact-link{display:inline-flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;border:2px solid rgba(255,255,255,.92);border-radius:999px;padding:.18rem .72rem;line-height:1.25;box-shadow:3px 3px 0 rgba(17,17,15,.18);transition:transform .16s ease,background .16s ease,color .16s ease}.top-contact-link:hover{background:#fff;color:var(--pink);transform:translateY(-1px)}.top-contact-link:focus-visible{outline:3px solid var(--ink);outline-offset:3px}.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1240px;margin:auto;padding:1rem 1.2rem}.logo{display:flex;align-items:center;gap:.75rem;color:var(--ink);text-decoration:none;font-weight:900}.logo img{width:90px;height:90px;object-fit:contain}.logo span{font-family:"Amatic SC";font-size:2.45rem;line-height:.85}.menu{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}.menu a{color:var(--ink);text-decoration:none;font-size:.82rem;font-weight:900;text-transform:uppercase;padding:.7rem .85rem;border-radius:999px}.menu a:hover,.menu .active{background:#fff;box-shadow:0 0 0 2px var(--orange)}.cta{background:var(--lav)!important}.hero{max-width:1240px;margin:auto;min-height:690px;display:grid;grid-template-columns:1fr 1.05fr;gap:2rem;align-items:center;position:relative;padding:3rem 1.2rem 5rem;overflow:hidden}.hero:after{content:"";position:absolute;left:-5vw;right:-5vw;bottom:-1px;height:120px;background:var(--soft);clip-path:polygon(0 34%,12% 50%,25% 31%,40% 45%,55% 27%,70% 45%,86% 30%,100% 48%,100% 100%,0 100%)}.kicker{font-weight:900;color:var(--sage);letter-spacing:.1em;text-transform:uppercase}.hero h1{font-size:clamp(3.4rem,7vw,7rem);line-height:.9;margin:.7rem 0;letter-spacing:-.045em}.orange{color:var(--orange)}.lav{color:var(--lav)}.sage{color:var(--sage)}.hero p{font-size:1.12rem;line-height:1.75;max-width:570px}.actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.8rem}.btn{border:0;background:var(--orange);color:#fff;text-decoration:none;font-weight:900;border-radius:999px;padding:1rem 1.35rem;display:inline-flex;align-items:center;gap:.4rem;box-shadow:7px 7px 0 var(--pink);cursor:pointer}.btn.alt{background:#fff;color:var(--sage);box-shadow:0 0 0 2px var(--sage)}.hero-art{position:relative;min-height:580px}.blob{position:absolute;inset:3% 0 7% 4%;background:var(--lav);border-radius:48% 52% 43% 57%;transform:rotate(-3deg)}.hero-img{position:absolute;right:2%;top:5%;width:78%;height:78%;object-fit:cover;border-radius:45% 55% 42% 58%;box-shadow:var(--shadow);border:10px solid #fff}.doodle{position:absolute;font-size:4rem;font-weight:900}.d1{right:0;top:7%;color:var(--orange)}.d2{left:0;bottom:15%;color:var(--sage)}.d3{right:12%;bottom:3%;color:var(--lav)}.service-strip{background:var(--soft);padding:3.5rem 1rem}.service-grid{max-width:1240px;margin:auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}.service{border-right:1px solid var(--line);padding:1rem}.service .icon{font-size:2.4rem;color:var(--orange)}.service h3{text-transform:uppercase;font-size:1rem}.service p{line-height:1.65}.service a{color:var(--orange);font-weight:900;text-decoration:none}.section{max-width:1240px;margin:auto;padding:4.5rem 1.2rem}.section-title{display:grid;grid-template-columns:.55fr 1fr;gap:2rem;align-items:end;margin-bottom:2rem}.section-title h2{font-size:clamp(3rem,6vw,5.8rem);line-height:.88;margin:0}.section-title p{line-height:1.75}.work-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.work{background:#fff;border:1px solid var(--line);border-radius:16px;padding:.8rem;box-shadow:0 12px 30px rgba(0,0,0,.08)}.work img{width:100%;height:230px;object-fit:cover;border-radius:12px}.pill{display:inline-block;margin-top:.7rem;background:var(--lav);padding:.35rem .7rem;border-radius:999px;font-size:.75rem;font-weight:900;text-transform:uppercase}.about{background:var(--sage);position:relative;overflow:hidden}.about .inner{max-width:1240px;margin:auto;padding:4rem 1.2rem;display:grid;grid-template-columns:.8fr 1.2fr .45fr;gap:2rem;align-items:center}.polaroid{background:#fff;padding:.9rem .9rem 3rem;border-radius:10px;box-shadow:var(--shadow);transform:rotate(-8deg)}.polaroid img{width:100%;height:300px;object-fit:cover;border-radius:8px}.about h2{font-size:clamp(2.8rem,5vw,5rem);line-height:.9}.tabs{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:1.5rem}.tab{border:2px solid var(--ink);background:#fff;color:var(--ink);text-decoration:none;border-radius:999px;padding:.7rem 1rem;font-weight:900}.tab.active{background:var(--pink);color:#fff}.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.gallery .polaroid{transform:rotate(var(--r));padding:.65rem .65rem 2.4rem;margin:0}.gallery img{width:100%;height:240px;object-fit:cover;border-radius:7px}.contact-wrap{display:grid;grid-template-columns:.8fr 1fr;gap:2rem}.contact-card{background:var(--orange);color:#fff;border-radius:40px;padding:2rem;position:relative;overflow:hidden}.contact-card h2{font-size:4rem;line-height:.9}.form{background:#fff;border-radius:40px;padding:2rem;box-shadow:var(--shadow)}label{font-weight:900;display:block;margin:.8rem 0 .35rem}input,select,textarea{width:100%;border:2px solid var(--line);border-radius:16px;padding:1rem;font:inherit}textarea{min-height:130px}.opt{display:flex;gap:.7rem;align-items:flex-start;margin:1rem 0}.opt input{width:auto}.notice{background:#fff3c7;border-radius:16px;padding:1rem}.chat{position:fixed;right:22px;bottom:22px;z-index:20}.chat-toggle{background:var(--pink);color:#fff;border:0;border-radius:999px;padding:1rem 1.2rem;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.18)}.chat-panel{display:none;width:min(380px,calc(100vw - 30px));background:#fff;border:2px solid var(--ink);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}.chat.open .chat-panel{display:block}.chat-head{background:var(--ink);color:#fff;padding:1rem;font-weight:900}.chat-body{padding:1rem}.footer{background:var(--sage);color:#fff;padding:1rem}.footer .inner{max-width:1240px;margin:auto;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem}@media(max-width:950px){.menu{display:none}.hero,.section-title,.about .inner,.contact-wrap{grid-template-columns:1fr}.service-grid,.work-grid,.gallery{grid-template-columns:1fr 1fr}.hero-art{min-height:460px}.hero h1{font-size:4rem}}@media(max-width:560px){.service-grid,.work-grid,.gallery{grid-template-columns:1fr}.logo img{width:70px;height:70px}.hero{padding-top:1.5rem}.hero-art{min-height:360px}.section{padding:3rem 1rem}}
/* Clean functional upgrade: dynamic gallery, hero slideshow, social dock, better mobile landscape */
.copy{font-size:1.08rem;line-height:1.78}.copy p{margin:0 0 1rem}.hero-slider{position:absolute;right:2%;top:5%;width:78%;height:78%;border-radius:45% 55% 42% 58%;box-shadow:var(--shadow);border:10px solid #fff;overflow:hidden;background:#fff}.hero-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.04);transition:opacity .8s ease,transform 4.2s ease}.hero-slider img.active{opacity:1;transform:scale(1)}.hero-img{display:none}.tabs button.tab{cursor:pointer}.gallery .is-hidden{display:none!important}.gallery figcaption strong{display:block;margin-top:.45rem}.project-text{font-size:.82rem;line-height:1.45;margin-top:.35rem}.project-text p{margin:.25rem 0}.gallery small{display:block;margin-top:.35rem;color:var(--sage);font-weight:900}.social-dock{position:fixed;right:18px;top:104px;z-index:30;display:flex;flex-direction:column;gap:.55rem}.social-dock a{width:52px;min-height:52px;border-radius:999px;background:#fff;color:var(--ink);text-decoration:none;display:grid;place-items:center;border:2px solid var(--ink);box-shadow:6px 6px 0 var(--pink);position:relative;transition:transform .18s ease,background .18s ease}.social-dock a:hover{transform:translateX(-4px) rotate(-4deg);background:var(--lime)}.social-dock span{font-size:1.35rem;font-weight:900}.social-dock em{position:absolute;right:62px;top:50%;transform:translateY(-50%);background:var(--ink);color:white;font-style:normal;font-size:.75rem;font-weight:900;padding:.35rem .55rem;border-radius:999px;opacity:0;pointer-events:none;white-space:nowrap}.social-dock a:hover em{opacity:1}.work-grid .work:nth-child(1),.gallery .polaroid:nth-child(1){transform:rotate(-2deg)}.gallery .polaroid{transition:opacity .16s ease, transform .16s ease}.gallery .polaroid:hover{transform:rotate(0deg) translateY(-5px)!important}
@media(max-width:950px){.social-dock{top:auto;right:12px;bottom:86px}.social-dock a{width:46px;min-height:46px}.social-dock em{display:none}.hero-slider{height:82%;width:84%;right:0}}
@media(max-width:560px){.work-grid,.gallery{grid-template-columns:1fr}.gallery img{height:300px}.hero-slider{width:88%;height:82%}}
@media (orientation: landscape) and (max-height: 520px) and (max-width: 950px){.hero{grid-template-columns:1fr 1fr;min-height:480px;padding-top:1rem}.hero h1{font-size:3.2rem}.hero p,.copy{font-size:.94rem}.hero-art{min-height:360px}.service-grid,.work-grid,.gallery{grid-template-columns:repeat(2,1fr)!important}.gallery img,.work img{height:210px}.section{padding:2.5rem 1rem}.section-title{grid-template-columns:1fr 1fr}.social-dock{right:10px;top:75px;bottom:auto}}


/* Live Creative Channel */
.channel-page{min-height:100vh;display:grid;place-items:center;padding:2rem;background:radial-gradient(circle at top left,#ffd6e8,transparent 35%),radial-gradient(circle at bottom right,#ffe1c5,transparent 35%),var(--cream)}
.channel-card{width:min(920px,100%);background:#fff;border-radius:36px;padding:2rem;box-shadow:var(--shadow)}
.channel-card h1{font-size:clamp(2.8rem,7vw,5.4rem);line-height:.9;margin:.8rem 0;color:var(--pink)}
.thread{max-height:460px;overflow:auto;background:#fff7ef;border:2px solid var(--line);border-radius:24px;padding:1rem;margin:1rem 0;scroll-behavior:smooth}.bubble{max-width:78%;padding:.9rem 1rem;border-radius:18px;margin:.55rem 0;background:white;box-shadow:0 8px 20px rgba(0,0,0,.06)}.bubble p{margin:.35rem 0;line-height:1.45}.bubble small{opacity:.65}.bubble.ness{margin-left:auto;background:#ffe0ec}.bubble.visitor{background:#eef1d9}.channel-form textarea{min-height:120px}.live-admin{display:grid;grid-template-columns:360px 1fr;gap:1rem}.live-list,.live-thread{background:#fff7ef;border-radius:24px;padding:1rem;border:1px solid var(--line)}.lead-row{width:100%;display:block;text-align:left;border:0;background:white;border-radius:16px;padding:.8rem;margin:.45rem 0;cursor:pointer;box-shadow:0 8px 18px rgba(0,0,0,.05)}.lead-row strong,.lead-row span,.lead-row small{display:block}.lead-row.unread{box-shadow:0 0 0 3px var(--pink);background:#fff0f6}.lead-row.active{background:#1f1f1f;color:white}.chat-panel input,.chat-panel textarea{margin:.35rem 0}.chat-panel [data-chat-start-status]{font-size:.9rem;font-weight:800;color:var(--pink)}
@media(max-width:820px){.live-admin{grid-template-columns:1fr}.bubble{max-width:94%}.channel-page{padding:1rem}.channel-card{padding:1rem}}

/* Logo update: use large readable full horizontal image; site name only appears as alt text */
.logo.logo-full{min-width:220px;max-width:340px;display:flex;align-items:center}.logo.logo-full img{width:clamp(210px,24vw,340px);height:auto;max-height:118px;object-fit:contain}.logo.logo-full span{display:none}.section-label{font-size:2rem;color:var(--orange)}.section-label.pink{color:var(--pink)}.about-butterfly{font-size:8rem}
@media(max-width:950px){.logo.logo-full{max-width:270px}.logo.logo-full img{width:clamp(190px,42vw,270px);max-height:96px}.nav{align-items:flex-start}}
@media(max-width:560px){.logo.logo-full{min-width:0;max-width:230px}.logo.logo-full img{width:210px;height:auto}.top{font-size:.78rem;line-height:1.35}.about-butterfly{font-size:5rem}}

/* 2026-06 responsive + gallery lightbox refinement */
.hero{overflow:visible;isolation:isolate}.hero:after{display:none}.service-strip{position:relative;margin-top:-32px;padding-top:5.25rem}.service-strip:before{content:"";position:absolute;left:50%;top:-118px;transform:translateX(-50%);width:100vw;height:126px;background:var(--soft);z-index:-1;clip-path:polygon(0 50%,4% 42%,8% 52%,12% 40%,16% 52%,20% 41%,24% 53%,28% 42%,32% 52%,36% 40%,40% 51%,44% 41%,48% 53%,52% 42%,56% 52%,60% 40%,64% 52%,68% 41%,72% 53%,76% 42%,80% 52%,84% 40%,88% 51%,92% 42%,96% 52%,100% 41%,100% 100%,0 100%)}
.hero-slider{aspect-ratio:4/5;height:auto;max-height:500px}.hero-art{display:grid;place-items:center}.blob{inset:7% 4% 9% 2%}.work img,.gallery img{cursor:zoom-in}.work,.gallery .polaroid{will-change:transform}.work:hover img,.gallery .polaroid:hover img{filter:saturate(1.06) contrast(1.02)}
.image-lightbox{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:clamp(16px,4vw,56px);background:rgba(17,17,15,.78);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .22s ease}.image-lightbox.is-open{opacity:1;pointer-events:auto}.image-lightbox__frame{position:relative;max-width:min(980px,94vw);max-height:92vh;background:#fff7ef;border:8px solid #fff;border-radius:34px;padding:clamp(10px,2vw,18px);box-shadow:0 30px 90px rgba(0,0,0,.42),0 0 0 3px var(--pink),14px 14px 0 var(--orange);transform:scale(.94) rotate(-1.5deg);transition:transform .25s cubic-bezier(.2,.8,.2,1)}.image-lightbox.is-open .image-lightbox__frame{transform:scale(1) rotate(-1.5deg)}.image-lightbox__frame:before,.image-lightbox__frame:after{content:"✦";position:absolute;width:58px;height:58px;display:grid;place-items:center;border-radius:50%;background:var(--lime);border:3px solid var(--ink);font-size:1.7rem;font-weight:900}.image-lightbox__frame:before{left:-24px;top:-24px;color:var(--pink)}.image-lightbox__frame:after{right:-24px;bottom:-24px;color:var(--orange)}.image-lightbox__img{display:block;max-width:100%;max-height:72vh;object-fit:contain;border-radius:22px;background:#fff}.image-lightbox__caption{padding:.9rem .35rem .25rem}.image-lightbox__caption h3{margin:.1rem 0;font-size:clamp(1.5rem,3vw,2.6rem);line-height:1;color:var(--pink)}.image-lightbox__caption p,.image-lightbox__text{margin:.4rem 0 0;line-height:1.55}.image-lightbox__text a{color:var(--pink);font-weight:900;text-decoration:underline;text-underline-offset:.18em}.image-lightbox__close{position:absolute;top:-18px;right:-18px;width:48px;height:48px;border-radius:50%;border:3px solid var(--ink);background:#fff;color:var(--ink);font-weight:900;font-size:1.4rem;cursor:pointer;box-shadow:5px 5px 0 var(--pink)}
@media(min-width:1600px){.service-strip:before{height:140px;top:-132px;clip-path:polygon(0 49%,3.5% 41%,7% 53%,10.5% 40%,14% 52%,17.5% 42%,21% 53%,24.5% 41%,28% 52%,31.5% 40%,35% 51%,38.5% 42%,42% 53%,45.5% 41%,49% 52%,52.5% 40%,56% 52%,59.5% 42%,63% 53%,66.5% 41%,70% 52%,73.5% 40%,77% 52%,80.5% 42%,84% 53%,87.5% 41%,91% 52%,94.5% 40%,98% 51%,100% 45%,100% 100%,0 100%)}}
@media(max-width:950px){.hero{gap:1rem;min-height:0}.hero-art{min-height:340px}.hero-slider{width:min(76vw,430px);height:auto;max-height:380px;right:auto;top:50%;left:50%;transform:translate(-50%,-50%)}.blob{inset:9% 8% 9% 8%}.service-strip{margin-top:-20px}}
@media(max-width:560px){.hero{padding:1.25rem 1rem 3rem}.hero h1{font-size:clamp(3rem,17vw,4.1rem)}.hero p,.copy{font-size:.98rem;line-height:1.6}.hero-art{min-height:260px;margin-top:.4rem}.hero-slider{width:min(72vw,300px);max-height:260px;border-width:7px}.blob{inset:8% 14% 12% 12%}.doodle{font-size:2.8rem}.service-grid{grid-template-columns:1fr}.work-grid{grid-template-columns:1fr 1fr;gap:.75rem}.work{padding:.55rem;border-radius:14px}.work img{height:170px}.gallery{grid-template-columns:1fr}.image-lightbox{padding:14px}.image-lightbox__frame{border-width:6px;border-radius:24px;box-shadow:0 22px 60px rgba(0,0,0,.36),0 0 0 2px var(--pink),8px 8px 0 var(--orange)}.image-lightbox__img{max-height:64vh}.image-lightbox__close{right:-10px;top:-14px}}
@media (orientation:landscape) and (max-height:520px) and (max-width:950px){.hero{grid-template-columns:minmax(0,1fr) minmax(240px,.85fr);align-items:center;min-height:0;padding:1rem 1rem 2.6rem}.hero-art{min-height:300px;grid-column:2;grid-row:1}.hero-slider{width:min(36vw,300px);max-height:270px}.hero h1{font-size:clamp(2.5rem,8vh,3.25rem)}.actions{margin-top:.8rem}.service-strip{padding-top:3.5rem}.work-grid,.gallery{grid-template-columns:repeat(2,1fr)!important}.work img,.gallery img{height:180px}.gallery .polaroid:first-child{grid-column:auto}}
@media(max-width:380px){.work img{height:150px}.hero-slider{width:74vw;max-height:230px}}

/* Reviews, calendar timeline and safer popups */
.reviews-section{position:relative}.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.review-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:1.2rem;box-shadow:0 12px 34px rgba(0,0,0,.08);cursor:pointer;transition:transform .18s ease,box-shadow .18s ease}.review-card:hover{transform:translateY(-4px) rotate(-1deg);box-shadow:var(--shadow)}.review-card img{width:72px;height:72px;object-fit:cover;border-radius:50%;float:right;margin:0 0 .6rem .8rem}.stars{color:var(--orange);letter-spacing:.08em;font-weight:900}.review-card p{line-height:1.6}.review-card strong,.review-card small{display:block}.review-card small{color:var(--sage);font-weight:900;margin-top:.25rem}.timeline-section{position:relative}.timeline-wrap{display:grid;grid-template-columns:90px 1fr;gap:1rem;align-items:start}.timeline-line{width:6px;min-height:100%;border-radius:999px;background:linear-gradient(var(--pink),var(--orange),var(--sage));justify-self:center;box-shadow:0 0 0 8px rgba(255,255,255,.55)}.timeline-list{display:grid;gap:.8rem}.timeline-item{width:100%;text-align:left;background:#fff;border:2px solid var(--line);border-radius:22px;padding:1rem 1.15rem;cursor:pointer;box-shadow:0 10px 28px rgba(0,0,0,.06);position:relative}.timeline-item:before{content:"";position:absolute;left:-62px;top:50%;width:18px;height:18px;border-radius:50%;background:var(--pink);border:4px solid #fff;box-shadow:0 0 0 2px var(--ink)}.timeline-item:hover{border-color:var(--orange);transform:translateX(4px)}.timeline-item span,.timeline-item small{display:block;font-weight:900;color:var(--sage)}.timeline-item strong{display:block;font-family:Fraunces,Georgia,serif;font-size:1.35rem;line-height:1.05;margin:.2rem 0;color:var(--ink)}.content-popup{position:fixed;inset:0;z-index:10000;display:grid;place-items:center;padding:clamp(14px,4vw,56px);background:rgba(17,17,15,.78);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .22s ease}.content-popup.is-open{opacity:1;pointer-events:auto}.content-popup__frame{position:relative;width:min(760px,94vw);max-height:92vh;overflow:auto;background:#fff7ef;border:8px solid #fff;border-radius:34px;padding:clamp(12px,2vw,18px);box-shadow:0 30px 90px rgba(0,0,0,.42),0 0 0 3px var(--pink),14px 14px 0 var(--orange)}.content-popup__img{display:block;width:100%;max-height:58vh;object-fit:contain;border-radius:22px;background:#fff;margin:0 auto}.content-popup__body{width:100%;margin:0 auto;padding:.9rem .35rem .2rem}.content-popup__body h3{margin:.1rem 0;font-size:clamp(1.7rem,4vw,3rem);line-height:1.02;color:var(--pink);overflow-wrap:anywhere;hyphens:auto}.content-popup__body p{line-height:1.6}.content-popup__meta{font-weight:900;color:var(--sage);margin-top:.4rem}.content-popup__close{position:absolute;top:-18px;right:-18px;width:48px;height:48px;border-radius:50%;border:3px solid var(--ink);background:#fff;color:var(--ink);font-weight:900;font-size:1.4rem;cursor:pointer;box-shadow:5px 5px 0 var(--pink)}.lead-actions{display:flex!important;gap:.35rem;flex-wrap:wrap;margin-top:.55rem}.lead-actions em{font-style:normal;font-size:.75rem;font-weight:900;border-radius:999px;background:#fff7ef;color:var(--ink);padding:.35rem .55rem;border:1px solid var(--line);pointer-events:auto}.lead-actions em:hover{background:var(--lime)}.lead-actions em.danger{color:#b00020}.lead-row.is-closed{opacity:.75}.lead-row.is-archived{opacity:.62}.lead-row.is-closed strong:after{content:" geschlossen";font-family:Inter,Arial,sans-serif;font-size:.7rem;color:var(--orange)}
@media(max-width:820px){.reviews-grid{grid-template-columns:1fr}.timeline-wrap{grid-template-columns:34px 1fr}.timeline-item:before{left:-38px}.content-popup__frame{border-width:6px;border-radius:24px}.content-popup__img{max-height:50vh}}

/* Local butterfly layer: decorative, cookie-controlled, fully local image assets. */
.butterfly-layer{position:fixed;inset:0;z-index:8;pointer-events:none;overflow:hidden;contain:layout paint style;perspective:760px}.butterfly-ui{position:fixed;right:18px;top:calc(50% + 148px);transform:translateY(-50%);z-index:31;display:grid;gap:.65rem;justify-items:end}.butterfly-toggle{width:52px;min-height:52px;border-radius:999px;background:#fff;color:var(--ink);border:2px solid var(--ink);box-shadow:6px 6px 0 var(--pink);font:900 1.45rem/1 Inter,Arial,sans-serif;display:grid;place-items:center;cursor:pointer;transition:transform .18s ease,background .18s ease}.butterfly-toggle:hover,.butterfly-ui.is-open .butterfly-toggle{transform:translateX(-4px) rotate(-4deg);background:var(--lime)}.butterfly-toggle[aria-pressed="false"]{opacity:.72;filter:saturate(.45)}.butterfly-toggle:focus-visible,.butterfly-panel input:focus-visible,.butterfly-panel button:focus-visible{outline:3px solid var(--orange);outline-offset:3px}.butterfly-panel{display:none;width:min(310px,calc(100vw - 92px));background:#fff7ef;border:2px solid var(--ink);border-radius:24px;padding:1rem;box-shadow:var(--shadow),8px 8px 0 var(--pink);text-align:left}.butterfly-ui.is-open .butterfly-panel{display:block}.butterfly-panel h3{margin:.05rem 0 .5rem;font-size:1.65rem;line-height:.95;color:var(--pink)}.butterfly-panel p{margin:.35rem 0 .8rem;line-height:1.45;font-size:.9rem}.butterfly-control{display:grid;gap:.35rem;margin:.8rem 0}.butterfly-control label{margin:0;display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.86rem;text-transform:uppercase;letter-spacing:.04em}.butterfly-control input[type="range"]{padding:0;border:0;border-radius:999px;accent-color:var(--pink)}.butterfly-control input[type="checkbox"]{width:auto;accent-color:var(--pink)}.butterfly-inline{display:flex!important;justify-content:flex-start!important;gap:.55rem!important}.butterfly-mini{border:2px solid var(--ink);border-radius:999px;background:white;color:var(--ink);padding:.55rem .8rem;font-weight:900;cursor:pointer}.butterfly-mini:hover{background:var(--lime)}
.butterfly{position:absolute;left:0;top:0;width:var(--bf-width,58px);height:var(--bf-height,48px);opacity:var(--bf-opacity,.94);will-change:transform;filter:drop-shadow(0 10px 12px rgba(17,17,15,.16));transform-style:preserve-3d}.butterfly__inner{position:absolute;left:50%;top:50%;width:100%;height:100%;transform:translate(-50%,-50%) rotateX(58deg);transform-style:preserve-3d}.butterfly__body,.butterfly__wing{position:absolute;top:50%;left:50%;display:block;transform-style:preserve-3d;backface-visibility:visible}.butterfly__body{width:var(--bf-body-w,10px);height:var(--bf-body-h,34px);z-index:4;transform:translate(-50%,-50%) translateZ(2px)}.butterfly__body img,.butterfly__wing img{display:block;width:100%;height:100%;object-fit:contain;user-select:none;-webkit-user-drag:none;pointer-events:none}.butterfly__wing{width:var(--bf-wing-w,32px);height:var(--bf-wing-h,44px);z-index:2;animation-duration:var(--bf-flap,.42s);animation-timing-function:cubic-bezier(.45,.02,.55,.98);animation-iteration-count:infinite;animation-direction:alternate;animation-delay:var(--bf-delay,0s);filter:saturate(1.05) contrast(1.03)}.butterfly__wing--left{margin-left:calc(var(--bf-wing-w,32px) * -1 + var(--bf-hinge,3px));margin-top:calc(var(--bf-wing-h,44px) * -.5);transform-origin:100% 50%;animation-name:butterfly-flap-left}.butterfly__wing--right{margin-left:calc(var(--bf-hinge,3px) * -1);margin-top:calc(var(--bf-wing-h,44px) * -.5);transform-origin:0 50%;animation-name:butterfly-flap-right}.butterfly__wing--right img{transform:scaleX(-1)}.butterfly.is-soft{opacity:.74}.butterfly.is-tiny{filter:drop-shadow(0 6px 7px rgba(17,17,15,.12))}.butterfly.is-far{opacity:.62;filter:blur(.12px) drop-shadow(0 5px 7px rgba(17,17,15,.09))}.butterfly[data-variant="2"] .butterfly__inner{transform:translate(-50%,-50%) rotateX(54deg)}.butterfly[data-variant="4"] .butterfly__inner{transform:translate(-50%,-50%) rotateX(60deg)}@keyframes butterfly-flap-left{0%{transform:rotateY(82deg) rotateZ(-9deg) translateZ(2px)}55%{transform:rotateY(18deg) rotateZ(2deg) translateZ(5px)}100%{transform:rotateY(-6deg) rotateZ(5deg) translateZ(1px)}}@keyframes butterfly-flap-right{0%{transform:rotateY(-82deg) rotateZ(9deg) translateZ(2px)}55%{transform:rotateY(-18deg) rotateZ(-2deg) translateZ(5px)}100%{transform:rotateY(6deg) rotateZ(-5deg) translateZ(1px)}}@media(max-width:950px){.butterfly-ui{right:12px;top:auto;bottom:146px}.butterfly-toggle{width:46px;min-height:46px}.butterfly-panel{width:min(292px,calc(100vw - 78px))}}@media(max-width:560px){.butterfly-ui{bottom:138px}.butterfly-panel{max-height:64vh;overflow:auto}}@media(prefers-reduced-motion:reduce){.butterfly-layer{display:none}.butterfly-toggle{opacity:.65}.butterfly-panel p:after{content:" Bewegungsreduktion ist aktiv.";font-weight:900;color:var(--orange)}}

/* 2026-06 popup rendering hardening: no accidental horizontal scrollbars, clean wrapping */
.content-popup{overflow:hidden}.content-popup__frame{box-sizing:border-box;width:min(820px,calc(100vw - 32px));max-height:calc(100vh - 54px);overflow:hidden;display:flex;flex-direction:column}.content-popup__img{flex:0 1 auto;max-width:100%;max-height:min(52vh,520px);object-fit:contain}.content-popup__body{box-sizing:border-box;min-width:0;overflow:hidden}.content-popup__body h3{max-width:100%;word-break:normal;overflow-wrap:anywhere;text-wrap:balance}.content-popup__meta{overflow-wrap:anywhere}.content-popup__body p{max-width:100%;margin-bottom:0;overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:7;-webkit-box-orient:vertical;overflow:hidden}.content-popup__close{z-index:2}@media(max-width:680px){.content-popup{padding:14px}.content-popup__frame{width:calc(100vw - 28px);max-height:calc(100vh - 28px);border-width:6px;border-radius:24px;padding:12px;box-shadow:0 22px 60px rgba(0,0,0,.36),0 0 0 2px var(--pink),8px 8px 0 var(--orange)}.content-popup__img{max-height:42vh}.content-popup__body h3{font-size:clamp(1.55rem,9vw,2.35rem)}.content-popup__body p{-webkit-line-clamp:6}.content-popup__close{right:-8px;top:-12px}}

/* Footer legal popup: editable in backend, keyboard-friendly, isolated from content popups */
.legal-footer-links{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;flex-wrap:wrap}.legal-footer-links button{appearance:none;border:0;background:transparent;color:inherit;font:inherit;font-weight:900;cursor:pointer;padding:.12rem .08rem;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:4px}.legal-footer-links button:hover{color:var(--pink)}.legal-footer-links button:focus-visible{outline:3px solid var(--orange);outline-offset:4px;border-radius:8px}.legal-popup{position:fixed;inset:0;z-index:10020;display:grid;place-items:center;padding:clamp(14px,4vw,48px);background:rgba(17,17,15,.78);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .22s ease;overflow:hidden}.legal-popup.is-open{opacity:1;pointer-events:auto}.legal-popup__frame{box-sizing:border-box;position:relative;width:min(900px,calc(100vw - 32px));max-height:calc(100vh - 48px);background:#fff7ef;border:8px solid #fff;border-radius:34px;padding:clamp(14px,2.4vw,22px);box-shadow:0 30px 90px rgba(0,0,0,.42),0 0 0 3px var(--pink),14px 14px 0 var(--orange);display:flex;flex-direction:column;overflow:hidden}.legal-popup__close{position:absolute;top:-18px;right:-18px;width:48px;height:48px;border-radius:50%;border:3px solid var(--ink);background:#fff;color:var(--ink);font-weight:900;font-size:1.4rem;cursor:pointer;box-shadow:5px 5px 0 var(--pink);z-index:3}.legal-popup__tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin:0 2.5rem 1rem 0}.legal-popup__tabs button{border:2px solid var(--ink);background:#fff;border-radius:999px;padding:.58rem .88rem;font-weight:900;cursor:pointer;color:var(--ink)}.legal-popup__tabs button.is-active,.legal-popup__tabs button:hover{background:var(--lime)}.legal-popup__content{display:none;min-height:0;overflow:auto;overflow-x:hidden;padding:.15rem .45rem .4rem 0;color:var(--ink);line-height:1.62}.legal-popup__content.is-active{display:block}.legal-popup__content h2{margin:.1rem 0 .8rem;color:var(--pink);font-size:clamp(2rem,4vw,3.2rem);line-height:1}.legal-popup__content h3,.legal-popup__content h4{margin:1rem 0 .35rem;color:var(--ink)}.legal-popup__content p{margin:.55rem 0;overflow-wrap:anywhere}.legal-popup__content em{color:#64594f}@media(max-width:680px){.legal-popup{padding:14px}.legal-popup__frame{width:calc(100vw - 28px);max-height:calc(100vh - 28px);border-width:6px;border-radius:24px;box-shadow:0 22px 60px rgba(0,0,0,.36),0 0 0 2px var(--pink),8px 8px 0 var(--orange)}.legal-popup__close{right:-8px;top:-12px}.legal-popup__tabs{margin-right:1.8rem}.legal-popup__tabs button{padding:.5rem .7rem;font-size:.88rem}.legal-popup__content h2{font-size:clamp(1.8rem,10vw,2.5rem)}}

/* Senior-safe polish: keep butterfly control in the right dock stack and below socials, without covering mobile CTAs. */
:root{--accent_pink:var(--pink)}
.chat-toggle,.chat .btn{background:var(--accent_pink,var(--pink));color:#fff}
.about .copy + .btn{margin-top:1.45rem}.about-butterfly.has-image{display:flex;align-items:center;justify-content:center}.about-butterfly.has-image img{display:block;width:clamp(82px,12vw,180px);max-width:100%;height:auto;object-fit:contain;filter:drop-shadow(0 18px 24px rgba(17,17,15,.14))}
@media(max-width:950px){.social-dock{bottom:158px}.butterfly-ui{top:auto;bottom:92px;right:12px}.chat{right:12px;bottom:18px}.butterfly-panel{transform:translateY(-8px)}}
@media(max-width:560px){.social-dock{bottom:152px}.butterfly-ui{bottom:88px}.about .copy + .btn{margin-top:1.7rem}.about-butterfly.has-image img{width:clamp(76px,32vw,138px)}}

/* 2026-06 lightbox browsing and matching frames for review/calendar popups */
.image-lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:46px;height:58px;border:3px solid var(--ink);border-radius:999px;background:#fff;color:var(--ink);font:900 2.1rem/1 Inter,Arial,sans-serif;cursor:pointer;box-shadow:5px 5px 0 var(--pink);display:grid;place-items:center}.image-lightbox__nav:hover{background:var(--lime)}.image-lightbox__nav--prev{left:-28px}.image-lightbox__nav--next{right:-28px}.image-lightbox__nav[hidden]{display:none}.image-lightbox__count{display:block;margin-top:.35rem;color:var(--sage);font-weight:900}.image-lightbox__img{cursor:default}.work img,.gallery img{cursor:zoom-in}.work img:focus-visible,.gallery img:focus-visible{outline:4px solid var(--orange);outline-offset:4px;border-radius:18px}
.content-popup__frame{max-width:min(980px,94vw);width:auto;min-width:min(760px,94vw);background:#fff7ef;border:8px solid #fff;border-radius:34px;padding:clamp(10px,2vw,18px);box-shadow:0 30px 90px rgba(0,0,0,.42),0 0 0 3px var(--pink),14px 14px 0 var(--orange);transform:scale(.94) rotate(-1.5deg);transition:transform .25s cubic-bezier(.2,.8,.2,1)}.content-popup.is-open .content-popup__frame{transform:scale(1) rotate(-1.5deg)}.content-popup__frame:before,.content-popup__frame:after{content:"✦";position:absolute;width:58px;height:58px;display:grid;place-items:center;border-radius:50%;background:var(--lime);border:3px solid var(--ink);font-size:1.7rem;font-weight:900;z-index:1}.content-popup__frame:before{left:-24px;top:-24px;color:var(--pink)}.content-popup__frame:after{right:-24px;bottom:-24px;color:var(--orange)}.content-popup__close{position:absolute;top:-18px;right:-18px;width:48px;height:48px;border-radius:50%;border:3px solid var(--ink);background:#fff;color:var(--ink);font-weight:900;font-size:1.4rem;cursor:pointer;box-shadow:5px 5px 0 var(--pink);z-index:5;line-height:1;display:grid;place-items:center}.content-popup__img{border-radius:22px;background:#fff}.content-popup__body{padding:.9rem .35rem .25rem}@media(max-width:680px){.image-lightbox__nav{width:42px;height:50px;font-size:1.8rem}.image-lightbox__nav--prev{left:-13px}.image-lightbox__nav--next{right:-13px}.content-popup__frame{min-width:0;width:calc(100vw - 28px);border-width:6px;border-radius:24px;box-shadow:0 22px 60px rgba(0,0,0,.36),0 0 0 2px var(--pink),8px 8px 0 var(--orange)}.content-popup__frame:before,.content-popup__frame:after{width:44px;height:44px;font-size:1.25rem}.content-popup__frame:before{left:-14px;top:-14px}.content-popup__frame:after{right:-14px;bottom:-14px}.content-popup__close{right:-10px;top:-14px}}

/* 2026-06 popup z-index fix: keep round close/navigation buttons above decorative frames and shadows. */
.image-lightbox__frame,
.content-popup__frame,
.legal-popup__frame{
  isolation:isolate;
  overflow:visible;
}
.image-lightbox__frame:before,
.image-lightbox__frame:after,
.content-popup__frame:before,
.content-popup__frame:after{
  z-index:0;
  pointer-events:none;
}
.image-lightbox__img,
.image-lightbox__caption,
.content-popup__img,
.content-popup__body,
.legal-popup__tabs,
.legal-popup__content{
  position:relative;
  z-index:2;
}
.image-lightbox__close,
.content-popup__close,
.legal-popup__close{
  z-index:60;
  pointer-events:auto;
}
.image-lightbox__nav{
  z-index:55;
  pointer-events:auto;
}
@media(max-width:680px){
  .image-lightbox__close,
  .content-popup__close,
  .legal-popup__close{
    z-index:60;
  }
}

/* 2026-06 logo color + mobile full-width header refinement */
@media(max-width:950px){
  .nav{justify-content:center;align-items:center;padding-left:1rem;padding-right:1rem}
  .logo.logo-full{width:100%;min-width:0;max-width:none;justify-content:center}
  .logo.logo-full img{width:100%;max-width:min(520px,100%);max-height:none;height:auto}
}
@media(max-width:560px){
  .logo.logo-full{width:100%;max-width:none}
  .logo.logo-full img{width:100%;max-width:100%;height:auto;max-height:none}
}

/* Pink button shadow consistency: pink controls use the orange offset shadow. */
.chat-toggle,
.chat .btn,
.tab.active {
  box-shadow: 6px 6px 0 var(--orange);
}
.chat-toggle:hover,
.chat .btn:hover,
.tab.active:hover {
  transform: translateY(-1px);
}


/* SEO landing pages: service-specific, indexable subpages without changing the home design. */
.landing-hero{max-width:1240px;margin:auto;display:grid;grid-template-columns:1fr .78fr;gap:2rem;align-items:center;padding:3.2rem 1.2rem 4.2rem}
.landing-hero h1{font-size:clamp(3.4rem,7vw,6.8rem);line-height:.88;margin:.7rem 0;color:var(--pink);letter-spacing:-.045em}
.landing-hero p{font-size:1.14rem;line-height:1.72;max-width:620px}
.landing-card{margin:0;background:#fff;padding:.9rem .9rem 2.3rem;border-radius:18px;box-shadow:var(--shadow);transform:rotate(3deg)}
.landing-card img{display:block;width:100%;height:min(520px,52vw);object-fit:cover;border-radius:14px}
.landing-copy{background:#fff;border-radius:34px;padding:clamp(1.2rem,3vw,2rem);box-shadow:var(--shadow);font-size:1.05rem;line-height:1.78}
.landing-copy h2,.landing-copy h3{color:var(--pink);margin:1.1rem 0 .45rem}
.landing-copy p{margin:.6rem 0 1rem}
.landing-copy ul{padding-left:1.2rem}
.landing-copy li{margin:.35rem 0}
.landing-services .service-grid{grid-template-columns:repeat(3,1fr)}
@media(max-width:950px){.landing-hero{grid-template-columns:1fr}.landing-card{max-width:620px}.landing-services .service-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.landing-hero{padding-top:1.6rem}.landing-card img{height:340px}.landing-services .service-grid{grid-template-columns:1fr}}


/* Structured top burger + creative-offer navigation */
.top{position:relative;z-index:70}
.top-burger{position:relative;display:inline-block;text-align:left}
.top-burger summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:.45rem;background:#fff;color:var(--pink);border:2px solid var(--ink);border-radius:999px;padding:.28rem .82rem;box-shadow:5px 5px 0 var(--orange);font-weight:1000;letter-spacing:.08em}
.top-burger summary::-webkit-details-marker{display:none}
.top-burger summary span{font-size:1.2rem;line-height:1}
.top-burger-panel{position:absolute;right:0;top:calc(100% + .7rem);width:min(680px,calc(100vw - 24px));background:#fff7ef;color:var(--ink);border:2px solid var(--ink);border-radius:28px;padding:1rem;box-shadow:var(--shadow),10px 10px 0 var(--orange);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;text-transform:none;letter-spacing:0}
.top-burger-panel strong{display:block;color:var(--pink);font-family:Fraunces,Georgia,serif;font-size:1.1rem;line-height:1;margin:0 0 .45rem}
.top-burger-panel a{display:block;color:var(--ink);text-decoration:none;font-weight:900;border-radius:14px;padding:.55rem .6rem}
.top-burger-panel a:hover,.top-burger-panel a:focus-visible{background:#fff;box-shadow:0 0 0 2px var(--pink)}
.nav-dropdown{position:relative}
.nav-dropdown>button{color:var(--ink);background:transparent;border:0;text-decoration:none;font-size:.82rem;font-weight:900;text-transform:uppercase;padding:.7rem .85rem;border-radius:999px;cursor:pointer;font-family:inherit}
.nav-dropdown:hover>button,.nav-dropdown:focus-within>button{background:#fff;box-shadow:0 0 0 2px var(--orange)}
.nav-dropdown__menu{position:absolute;left:0;top:calc(100% + .35rem);min-width:230px;background:#fff;border:2px solid var(--ink);border-radius:20px;padding:.45rem;box-shadow:var(--shadow),7px 7px 0 var(--orange);display:none;z-index:80}
.nav-dropdown:hover .nav-dropdown__menu,.nav-dropdown:focus-within .nav-dropdown__menu{display:block}
.nav-dropdown__menu a{display:block;border-radius:14px;white-space:nowrap}
.nav-tips-short{display:none}
@media(max-width:1120px){.nav-tips-full{display:none}.nav-tips-short{display:inline}}
@media(max-width:950px){.top-burger-panel{right:50%;transform:translateX(50%);grid-template-columns:1fr 1fr}.nav-dropdown__menu{position:static;margin-top:.3rem}.nav-dropdown:hover .nav-dropdown__menu,.nav-dropdown:focus-within .nav-dropdown__menu{display:none}}
@media(max-width:560px){.top{justify-content:center;gap:.45rem;padding:.55rem .45rem}.top-burger{position:static}.top-burger-panel{position:fixed;left:10px;right:10px;top:54px;width:auto;max-height:calc(100vh - 72px);overflow:auto;transform:none;grid-template-columns:1fr}.top-contact-link{font-size:.72rem}.top-text{font-size:.72rem}}

/* Instagram: local CSS-only stylized glyph, no external icon asset. */
.ig-glyph{width:1.35rem;height:1.35rem;display:block;border-radius:.38rem;background:radial-gradient(circle at 72% 28%,#fff 0 7%,transparent 8%),radial-gradient(circle at 50% 54%,transparent 0 31%,#fff 32% 43%,transparent 44%),linear-gradient(135deg,#7b3cff,#ff3a8c 52%,#ffb000);box-shadow:inset 0 0 0 2px #fff}
.social-dock a[href*="instagram" i] span,.social-dock a[href*="instagr.am" i] span{font-size:0}

/* Portfolio multi-select feedback */
.portfolio-help{margin-top:-1rem;margin-bottom:1rem;color:var(--sage);font-weight:900}
.tabs .tab.active{box-shadow:6px 6px 0 var(--orange)}
.section-title h1{font-size:clamp(3rem,6vw,5.8rem);line-height:.88;margin:0;font-family:Fraunces,Georgia,serif}

/* Mobile butterfly settings must stay fully reachable. */
@media(max-width:560px){
  .butterfly-ui.is-open{left:10px;right:10px;bottom:74px;justify-items:stretch}
  .butterfly-ui.is-open .butterfly-toggle{justify-self:end}
  .butterfly-panel{width:100%!important;max-height:calc(100vh - 142px);overflow:auto;overscroll-behavior:contain}
}
@media(max-height:620px){
  .butterfly-ui.is-open{top:10px!important;bottom:auto!important;transform:none}
  .butterfly-panel{max-height:calc(100vh - 86px);overflow:auto}
}

/* AAA UX navigation polish: logo gets the full row, menu sits underneath and never wraps. */
.nav{
  flex-direction:column;
  align-items:stretch;
  justify-content:center;
  gap:.85rem;
  max-width:1320px;
  padding:1.05rem clamp(1rem,3vw,2rem) 1.2rem;
}
.logo.logo-full{
  width:100%;
  justify-content:center;
  min-width:0;
}
.logo.logo-full img{
  width:min(100%,520px);
  height:auto;
  max-height:128px;
  object-fit:contain;
}
.menu{
  width:100%;
  justify-content:center;
  flex-wrap:nowrap;
  gap:clamp(.22rem,.7vw,.6rem);
  white-space:nowrap;
  overflow-x:auto;
  overflow-y:visible;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:.18rem .12rem .34rem;
}
.menu::-webkit-scrollbar{display:none}
.menu a,.nav-dropdown>button{
  flex:0 0 auto;
  font-size:clamp(.72rem,1.08vw,.86rem);
  padding:.68rem clamp(.62rem,1.05vw,.92rem);
}
.nav-tips-full{display:inline!important}.nav-tips-short{display:none!important}

/* Burger: top-right premium floating control; it no longer changes the pink bar layout. */
.top{padding-right:5.8rem;min-height:48px}
.top-burger{
  position:fixed;
  top:12px;
  right:16px;
  z-index:10000;
}
.top-burger summary{
  min-width:48px;
  min-height:48px;
  justify-content:center;
  padding:.58rem .72rem;
  background:rgba(255,255,255,.92);
  color:var(--ink);
  border:3px solid var(--ink);
  box-shadow:6px 6px 0 var(--pink),0 14px 34px rgba(17,17,15,.18);
  backdrop-filter:blur(10px);
  letter-spacing:0;
}
.top-burger summary:hover{transform:translateY(-1px);background:#fff;box-shadow:6px 6px 0 var(--orange),0 16px 38px rgba(17,17,15,.2)}
.top-burger summary span{font-size:1.45rem}
.top-burger-panel{
  right:0;
  top:calc(100% + .85rem);
  width:min(520px,calc(100vw - 28px));
  grid-template-columns:1fr 1fr;
  border:3px solid var(--ink);
  box-shadow:0 24px 70px rgba(17,17,15,.24),10px 10px 0 var(--orange);
}
.top-burger-panel strong{color:var(--ink)}

/* Instagram button: robust colorful glyph even when icon text is empty/white. */
.social-dock a[href*="instagram" i],.social-dock a[href*="instagr.am" i]{
  background:linear-gradient(135deg,#7b3cff 0%,#ff3a8c 52%,#ffb000 100%);
  color:#fff;
}
.social-dock a[href*="instagram" i] span,.social-dock a[href*="instagr.am" i] span{font-size:0;width:1.55rem;height:1.55rem;display:block}
.ig-glyph{
  width:1.55rem;height:1.55rem;border-radius:.45rem;
  background:radial-gradient(circle at 72% 28%,#fff 0 7%,transparent 8%),radial-gradient(circle at 50% 54%,transparent 0 31%,#fff 32% 43%,transparent 44%),linear-gradient(135deg,#7b3cff,#ff3a8c 52%,#ffb000)!important;
  box-shadow:inset 0 0 0 2px #fff;
}

/* Portfolio filter multi-select: visual states and stable hiding. */
.tabs[role="group"] .tab{user-select:none;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}
.tabs[role="group"] .tab:hover{transform:translateY(-1px)}
.tabs[role="group"] .tab.active,.tabs[role="group"] .tab[aria-pressed="true"]{background:var(--pink);color:#fff;box-shadow:6px 6px 0 var(--orange)}
.gallery [data-gallery-item].is-hidden{display:none!important}

@media(max-width:950px){
  .nav{padding-top:.8rem}.menu{display:flex;justify-content:flex-start}
  .logo.logo-full img{max-height:102px;width:min(100%,440px)}
  .top-burger-panel{grid-template-columns:1fr 1fr;right:0;transform:none}
}
@media(max-width:560px){
  .top{justify-content:center;padding-right:4.9rem}.top-text{max-width:calc(100vw - 6.2rem)}
  .top-burger{top:8px;right:10px}.top-burger summary{min-width:44px;min-height:44px;padding:.5rem}.top-burger summary{font-size:0}.top-burger summary span{font-size:1.45rem}
  .top-burger-panel{position:fixed;left:10px;right:10px;top:62px;width:auto;grid-template-columns:1fr;max-height:calc(100vh - 78px);overflow:auto;transform:none}
  .logo.logo-full img{max-height:86px;width:100%}
}

/* 2026-06 client revision: logo and navigation back in one responsive row. */
.nav{
  flex-direction:row!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:clamp(.7rem,1.5vw,1.35rem)!important;
  max-width:1360px!important;
  padding:clamp(.75rem,1.5vw,1.05rem) clamp(4.8rem,8vw,7.2rem) clamp(.75rem,1.3vw,1rem) clamp(1rem,3vw,2rem)!important;
  overflow:visible!important;
}
.logo.logo-full{
  width:auto!important;
  min-width:clamp(176px,18vw,292px)!important;
  max-width:clamp(176px,22vw,330px)!important;
  flex:0 1 auto!important;
  justify-content:flex-start!important;
}
.logo.logo-full img{
  width:100%!important;
  max-width:330px!important;
  max-height:102px!important;
  object-fit:contain!important;
}
.menu{
  width:auto!important;
  flex:1 1 auto!important;
  min-width:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  flex-wrap:nowrap!important;
  white-space:nowrap!important;
  gap:clamp(.14rem,.45vw,.48rem)!important;
  overflow-x:auto!important;
  overflow-y:visible!important;
  padding:.22rem .22rem .44rem!important;
  scrollbar-width:none!important;
}
.menu::-webkit-scrollbar{display:none!important}
.menu a,.nav-dropdown>button{
  flex:0 0 auto!important;
  font-size:clamp(.64rem,.82vw,.84rem)!important;
  padding:.64rem clamp(.48rem,.72vw,.82rem)!important;
}
.nav-dropdown{flex:0 0 auto!important;position:relative!important}
.nav-dropdown__menu{max-height:min(68vh,420px);overflow:auto}
.top-contact-link{white-space:nowrap}.top-contact-link::first-letter{text-transform:uppercase}
.top{padding-right:5.35rem!important}.top-burger{top:10px!important;right:14px!important}
.social-dock{top:156px!important;right:18px!important}.butterfly-ui{top:calc(50% + 190px)!important;right:18px!important}

/* Slim, reachable butterfly settings panel. */
.butterfly-panel{
  width:min(256px,calc(100vw - 92px))!important;
  padding:.78rem!important;
  border-radius:18px!important;
  max-height:min(70vh,520px)!important;
  overflow:auto!important;
  overscroll-behavior:contain!important;
}
.butterfly-panel h3{font-size:1.36rem!important;margin:0 0 .35rem!important}.butterfly-panel p{font-size:.82rem!important;line-height:1.35!important;margin:.2rem 0 .55rem!important}.butterfly-control{margin:.54rem 0!important}.butterfly-control label{font-size:.74rem!important}.butterfly-mini{padding:.42rem .64rem!important;font-size:.78rem!important}

/* Landing preview uses category-random images inside the existing artistic frame. */
.landing-preview{position:relative;min-height:min(520px,52vw);overflow:hidden;padding:.9rem!important;background:#fff!important}
.landing-preview .landing-slider{position:relative!important;inset:auto!important;right:auto!important;top:auto!important;width:100%!important;height:min(500px,50vw)!important;border:0!important;border-radius:14px!important;box-shadow:none!important;background:#fff!important}
.landing-preview .landing-slider img{border-radius:14px!important}

@media(max-width:1180px){
  .nav{padding-right:5.8rem!important}.logo.logo-full{min-width:165px!important;max-width:240px!important}.menu a,.nav-dropdown>button{font-size:clamp(.61rem,.9vw,.76rem)!important;padding:.58rem .48rem!important}.nav-tips-full{display:none!important}.nav-tips-short{display:inline!important}
}
@media(max-width:980px){
  .nav{padding-right:4.6rem!important;gap:.55rem!important}.logo.logo-full{min-width:145px!important;max-width:190px!important}.menu{justify-content:flex-start!important}.social-dock{top:auto!important;right:12px!important;bottom:174px!important}.butterfly-ui{top:auto!important;right:12px!important;bottom:104px!important}.top-burger-panel{right:0!important;transform:none!important;grid-template-columns:1fr 1fr!important;max-height:calc(100vh - 76px);overflow:auto}.landing-preview{min-height:360px}.landing-preview .landing-slider{height:360px!important}
}
@media(max-width:720px){
  .nav{padding:.7rem 4.25rem .75rem .8rem!important}.logo.logo-full{min-width:118px!important;max-width:150px!important}.logo.logo-full img{max-height:76px!important}.menu a,.nav-dropdown>button{font-size:.64rem!important;padding:.52rem .44rem!important}.nav-dropdown__menu{position:fixed!important;left:10px!important;right:10px!important;top:112px!important;width:auto!important;max-height:calc(100vh - 132px)!important}.nav-dropdown:hover .nav-dropdown__menu,.nav-dropdown:focus-within .nav-dropdown__menu,.nav-dropdown.is-open .nav-dropdown__menu{display:block!important}
}
@media(max-width:560px){
  .top{padding-right:4.7rem!important;justify-content:flex-start!important}.top-contact-link{font-size:.72rem!important;padding:.24rem .56rem!important}.top-burger{top:7px!important;right:9px!important}.top-burger-panel{position:fixed!important;left:8px!important;right:8px!important;top:58px!important;width:auto!important;grid-template-columns:1fr!important;max-height:calc(100dvh - 70px)!important;overflow:auto!important;padding:.85rem!important}.nav{padding:.56rem 3.85rem .58rem .65rem!important}.logo.logo-full{min-width:92px!important;max-width:118px!important}.logo.logo-full img{max-height:62px!important}.menu{gap:.08rem!important;padding-bottom:.36rem!important}.menu a,.nav-dropdown>button{font-size:.58rem!important;padding:.46rem .35rem!important}.cta{display:none!important}.social-dock{bottom:166px!important}.butterfly-ui{bottom:96px!important}.butterfly-ui.is-open{left:8px!important;right:8px!important;bottom:72px!important;top:auto!important;justify-items:stretch!important}.butterfly-ui.is-open .butterfly-toggle{justify-self:end!important}.butterfly-panel{width:100%!important;max-height:calc(100dvh - 132px)!important}.landing-preview{min-height:320px}.landing-preview .landing-slider{height:320px!important}
}
@media(max-height:620px){
  .butterfly-ui.is-open{top:8px!important;bottom:auto!important;transform:none!important}.butterfly-panel{max-height:calc(100dvh - 74px)!important}.social-dock{top:136px!important;bottom:auto!important}
}

/* 2026-06 hotfix: creative-offer dropdown must be clickable on mouse, keyboard and touch. */
.menu{overflow:visible!important;}
.nav-dropdown.is-open>.nav-dropdown__menu,
.nav-dropdown:hover>.nav-dropdown__menu,
.nav-dropdown:focus-within>.nav-dropdown__menu{display:block!important;}
.nav-dropdown__menu{z-index:10050!important;}
.nav-dropdown__menu a{pointer-events:auto!important;}
@media(max-width:720px){
  .menu{overflow-x:auto!important;overflow-y:visible!important;}
  .nav-dropdown.is-open>.nav-dropdown__menu{display:block!important;position:fixed!important;left:8px!important;right:8px!important;top:112px!important;width:auto!important;max-height:calc(100dvh - 128px)!important;overflow:auto!important;}
}

/* 2026-06 hotfix: butterfly settings open from the top edge for maximum usable height. */
.butterfly-ui.is-open{
  top:8px!important;
  bottom:auto!important;
  right:12px!important;
  transform:none!important;
  justify-items:end!important;
  z-index:10060!important;
}
.butterfly-ui.is-open .butterfly-panel{
  max-height:calc(100dvh - 76px)!important;
  overflow:auto!important;
  overscroll-behavior:contain!important;
}
@media(max-width:560px){
  .butterfly-ui.is-open{left:8px!important;right:8px!important;top:8px!important;bottom:auto!important;justify-items:stretch!important;}
  .butterfly-ui.is-open .butterfly-toggle{justify-self:end!important;}
  .butterfly-ui.is-open .butterfly-panel{width:100%!important;max-height:calc(100dvh - 72px)!important;}
}


/* 2026-06 refinement: on smaller screens the full navigation is hidden and the logo gets the full row. */
@media(max-width:980px){
  .nav{
    display:flex!important;
    justify-content:center!important;
    align-items:center!important;
    padding:.85rem 5rem .8rem .95rem!important;
    max-width:100%!important;
  }
  .nav .menu{
    display:none!important;
  }
  .logo.logo-full{
    flex:1 1 auto!important;
    width:100%!important;
    min-width:0!important;
    max-width:none!important;
    justify-content:center!important;
  }
  .logo.logo-full img{
    width:min(100%,520px)!important;
    max-width:100%!important;
    max-height:118px!important;
    height:auto!important;
    object-fit:contain!important;
  }
}
@media(max-width:560px){
  .nav{padding:.7rem 4.5rem .7rem .75rem!important;}
  .logo.logo-full img{width:min(100%,360px)!important;max-height:94px!important;}
}
@media(max-width:380px){
  .nav{padding-right:3.9rem!important;}
  .logo.logo-full img{max-height:78px!important;}
}

/* 2026-06 refinement: butterfly settings always open from the top with maximum usable height. */
.butterfly-ui.is-open{
  position:fixed!important;
  top:8px!important;
  bottom:auto!important;
  right:12px!important;
  transform:none!important;
  z-index:10070!important;
}
.butterfly-ui.is-open .butterfly-panel{
  max-height:calc(100dvh - 72px)!important;
  overflow:auto!important;
  -webkit-overflow-scrolling:touch!important;
}
@media(max-width:560px){
  .butterfly-ui.is-open{left:8px!important;right:8px!important;top:8px!important;bottom:auto!important;}
  .butterfly-ui.is-open .butterfly-panel{width:100%!important;max-height:calc(100dvh - 70px)!important;}
}

/* 2026-06 hotfix: keep readable content away from the fixed round right-side buttons on narrow / portrait screens. */
@media (max-width: 980px), (orientation: portrait) and (max-width: 1100px){
  :root{--right-action-safe:88px;}
  main > .section,
  .hero,
  .landing-hero,
  .landing-content,
  .about .inner,
  .footer .inner,
  .channel-card{
    padding-right:calc(1rem + var(--right-action-safe))!important;
  }
  .section-title,
  .landing-copy,
  .tips-copy,
  .copy,
  .contact-card,
  .form,
  .notice,
  .service,
  .work,
  .gallery figcaption,
  .landing-services,
  .contact-wrap{
    max-width:calc(100vw - var(--right-action-safe) - 24px)!important;
  }
  .landing-copy,
  .tips-copy,
  .copy,
  .section-title p,
  .contact-card p,
  .service p,
  .work p{
    overflow-wrap:anywhere;
    hyphens:auto;
  }
}

@media (max-width: 560px){
  :root{--right-action-safe:74px;}
  .social-dock{
    right:8px!important;
  }
  .social-dock a,
  .butterfly-toggle{
    width:46px!important;
    min-height:46px!important;
  }
  main > .section,
  .hero,
  .landing-hero,
  .landing-content,
  .about .inner,
  .footer .inner,
  .channel-card{
    padding-left:.9rem!important;
    padding-right:calc(.75rem + var(--right-action-safe))!important;
  }
  .contact-wrap,
  .service-grid,
  .work-grid,
  .gallery,
  .section-title{
    width:100%!important;
    max-width:calc(100vw - var(--right-action-safe) - 18px)!important;
  }
  .actions,
  .tabs{
    padding-right:var(--right-action-safe)!important;
  }
}

@media (max-width: 380px){
  :root{--right-action-safe:64px;}
  .social-dock a,
  .butterfly-toggle{
    width:42px!important;
    min-height:42px!important;
  }
  .social-dock span{font-size:1.08rem!important;}
  main > .section,
  .hero,
  .landing-hero,
  .landing-content,
  .about .inner,
  .footer .inner,
  .channel-card{
    padding-right:calc(.65rem + var(--right-action-safe))!important;
  }
}

/* Hide all decorative/preview sliders on narrow screens and portrait mobile/tablet layouts
   so text and controls remain fully readable and usable. */
@media (max-width: 700px), (max-width: 950px) and (orientation: portrait){
  .hero-art,
  .hero-slider,
  .landing-preview,
  .landing-slider,
  .tips-preview{
    display:none!important;
  }
  .hero,
  .landing-hero{
    grid-template-columns:1fr!important;
    min-height:auto!important;
  }
  .hero{
    padding-bottom:2.25rem!important;
  }
  .landing-content{
    grid-template-columns:1fr!important;
  }
}

/* 2026-06 hotfix: sliders must always be completely image-filled after responsive resizes.
   Uses cover-cropping instead of letterboxing and removes white backgrounds/gaps. */
.hero-art,
.landing-preview,
.tips-preview{
  background:transparent!important;
}
.hero-slider,
.landing-slider,
.landing-preview .landing-slider,
.tips-preview .landing-slider{
  display:block;
  overflow:hidden!important;
  background:transparent!important;
  line-height:0!important;
  contain:paint;
}
.hero-slider img,
.landing-slider img,
.landing-preview .landing-slider img,
.tips-preview .landing-slider img,
[data-slide]{
  position:absolute!important;
  inset:0!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  min-width:100%!important;
  min-height:100%!important;
  max-width:none!important;
  object-fit:cover!important;
  object-position:center center!important;
  border:0!important;
  margin:0!important;
  padding:0!important;
}
.hero-slider img:first-child,
.landing-slider img:first-child,
.tips-preview .landing-slider img:first-child{
  opacity:1;
}
.hero-slider img.active,
.landing-slider img.active,
.tips-preview .landing-slider img.active{
  opacity:1!important;
}
.hero-slider img:not(.active):not(:first-child),
.landing-slider img:not(.active):not(:first-child),
.tips-preview .landing-slider img:not(.active):not(:first-child){
  opacity:0;
}
.landing-preview,
.tips-preview{
  display:block;
  overflow:hidden!important;
}
.landing-preview .landing-slider,
.tips-preview .landing-slider{
  width:100%!important;
  height:100%!important;
  min-height:clamp(320px,50vw,500px)!important;
}
@media (min-width:701px) and (max-width:950px){
  .hero-art{min-height:clamp(360px,58vw,520px)!important;}
  .hero-slider{width:84%!important;height:84%!important;right:0!important;top:4%!important;}
  .landing-preview,
  .tips-preview{min-height:clamp(340px,56vw,500px)!important;}
  .landing-preview .landing-slider,
  .tips-preview .landing-slider{height:clamp(340px,56vw,500px)!important;min-height:clamp(340px,56vw,500px)!important;}
}
@media (min-width:951px){
  .landing-preview,
  .tips-preview{min-height:min(520px,52vw)!important;}
  .landing-preview .landing-slider,
  .tips-preview .landing-slider{height:min(500px,50vw)!important;min-height:min(500px,50vw)!important;}
}

/* 2026-06 hotfix: hide preview sliders as soon as the layout would wrap them into a new row. */
.slider-wrap-hidden,
.slider-wrap-hidden .hero-slider,
.slider-wrap-hidden .landing-slider{
  display:none!important;
}
.hero.slider-row-wrapped,
.landing-hero.slider-row-wrapped{
  grid-template-columns:1fr!important;
  min-height:auto!important;
}
.hero.slider-row-wrapped{
  padding-bottom:2.25rem!important;
}
.landing-hero.slider-row-wrapped + .landing-content{
  grid-template-columns:1fr!important;
}

/* 2026-06 final responsive pass: slider frames, mobile landscape visibility, smaller fixed buttons, tighter safe area. */
.top{
  font-size:clamp(.68rem,1.05vw,.82rem)!important;
  line-height:1.25!important;
  letter-spacing:.085em!important;
  padding-top:.48rem!important;
  padding-bottom:.48rem!important;
}
.top-text{line-height:1.25!important;}

/* Keep the homepage artwork inside its own frame at every responsive size. */
.hero{overflow:hidden!important;}
.hero > *{min-width:0!important;}
.hero-art{
  position:relative!important;
  width:100%!important;
  min-width:0!important;
  overflow:hidden!important;
  isolation:isolate!important;
}
.hero-art .blob,
.hero-art .doodle{pointer-events:none!important;}
.hero-slider{
  max-width:100%!important;
  max-height:100%!important;
  box-sizing:border-box!important;
  z-index:2!important;
}

/* The previous mobile safe zone was too large. Keep text readable, but give content width back. */
@media (max-width:980px), (orientation:portrait) and (max-width:1100px){
  :root{--right-action-safe:58px!important;}
  main > .section,
  .hero,
  .landing-hero,
  .landing-content,
  .about .inner,
  .footer .inner,
  .channel-card{
    padding-right:calc(.85rem + var(--right-action-safe))!important;
  }
  .section-title,
  .landing-copy,
  .tips-copy,
  .copy,
  .contact-card,
  .form,
  .notice,
  .service,
  .work,
  .gallery figcaption,
  .landing-services,
  .contact-wrap{
    max-width:calc(100vw - var(--right-action-safe) - 12px)!important;
  }
  .actions,
  .tabs{padding-right:calc(var(--right-action-safe) * .55)!important;}
  .social-dock{right:8px!important;gap:.42rem!important;}
  .social-dock a,
  .butterfly-toggle{
    width:42px!important;
    min-height:42px!important;
    box-shadow:4px 4px 0 var(--pink)!important;
  }
  .social-dock span{font-size:1.06rem!important;}
  .ig-glyph,.social-dock a[href*="instagram" i] span,.social-dock a[href*="instagr.am" i] span{width:1.2rem!important;height:1.2rem!important;}
}
@media (max-width:560px) and (orientation:portrait){
  :root{--right-action-safe:48px!important;}
  .social-dock{right:6px!important;bottom:142px!important;}
  .butterfly-ui{right:6px!important;bottom:84px!important;}
  .social-dock a,
  .butterfly-toggle{
    width:36px!important;
    min-height:36px!important;
    border-width:2px!important;
  }
  .social-dock span{font-size:.96rem!important;}
  main > .section,
  .hero,
  .landing-hero,
  .landing-content,
  .about .inner,
  .footer .inner,
  .channel-card{
    padding-left:.85rem!important;
    padding-right:calc(.55rem + var(--right-action-safe))!important;
  }
  .contact-wrap,
  .service-grid,
  .work-grid,
  .gallery,
  .section-title{
    max-width:calc(100vw - var(--right-action-safe) - 8px)!important;
  }
}
@media (max-width:380px) and (orientation:portrait){
  :root{--right-action-safe:42px!important;}
  .social-dock a,
  .butterfly-toggle{width:32px!important;min-height:32px!important;}
  main > .section,
  .hero,
  .landing-hero,
  .landing-content,
  .about .inner,
  .footer .inner,
  .channel-card{padding-right:calc(.5rem + var(--right-action-safe))!important;}
}

/* Portrait/narrow keeps sliders hidden, but phone landscape must show and scale them again. */
@media (orientation:landscape) and (max-width:950px) and (max-height:560px){
  .hero-art,
  .hero-slider,
  .landing-preview,
  .landing-slider,
  .tips-preview{
    display:block!important;
  }
  .hero,
  .landing-hero{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) minmax(180px,.72fr)!important;
    align-items:center!important;
    gap:clamp(.75rem,2.2vw,1.25rem)!important;
    min-height:auto!important;
    padding-top:clamp(.75rem,2vh,1.2rem)!important;
    padding-bottom:clamp(.8rem,2.6vh,1.35rem)!important;
    padding-right:calc(.75rem + 48px)!important;
  }
  .hero h1,
  .landing-hero h1{font-size:clamp(2.2rem,7.4vw,3.6rem)!important;line-height:.9!important;margin:.35rem 0!important;}
  .hero p,
  .landing-hero p,
  .copy{font-size:.88rem!important;line-height:1.52!important;}
  .actions{margin-top:.8rem!important;gap:.55rem!important;padding-right:0!important;}
  .btn{padding:.7rem .88rem!important;box-shadow:4px 4px 0 var(--pink)!important;font-size:.82rem!important;}
  .hero-art{
    min-height:clamp(220px,58vh,330px)!important;
    max-height:calc(100dvh - 120px)!important;
  }
  .hero-slider{
    position:absolute!important;
    left:50%!important;
    right:auto!important;
    top:50%!important;
    width:min(88%,330px)!important;
    height:min(84%,300px)!important;
    transform:translate(-50%,-50%)!important;
    border-width:6px!important;
    border-radius:36% 64% 42% 58%!important;
  }
  .landing-preview,
  .tips-preview{
    min-height:clamp(210px,58vh,330px)!important;
    max-height:calc(100dvh - 124px)!important;
    padding:.48rem!important;
    transform:rotate(1.5deg)!important;
  }
  .landing-preview .landing-slider,
  .tips-preview .landing-slider{
    position:relative!important;
    width:100%!important;
    height:100%!important;
    min-height:clamp(196px,54vh,310px)!important;
    border-radius:12px!important;
  }
  .slider-wrap-hidden,
  .slider-wrap-hidden .hero-slider,
  .slider-wrap-hidden .landing-slider{
    display:block!important;
  }
  .hero.slider-row-wrapped,
  .landing-hero.slider-row-wrapped{
    grid-template-columns:minmax(0,1fr) minmax(180px,.72fr)!important;
  }
  .social-dock{right:7px!important;top:96px!important;bottom:auto!important;}
  .butterfly-ui{right:7px!important;top:auto!important;bottom:22px!important;}
  .social-dock a,
  .butterfly-toggle{width:34px!important;min-height:34px!important;border-width:2px!important;box-shadow:3px 3px 0 var(--pink)!important;}
  .social-dock span{font-size:.9rem!important;}
}

/* Wider tablet landscape: keep sliders visible, but prevent them from overgrowing. */
@media (orientation:landscape) and (min-width:701px) and (max-width:1100px){
  .hero-art,.hero-slider,.landing-preview,.landing-slider,.tips-preview{display:block!important;}
  .hero,.landing-hero{grid-template-columns:minmax(0,1fr) minmax(260px,.82fr)!important;}
  .hero-art{min-height:clamp(330px,48vw,480px)!important;}
  .hero-slider{width:82%!important;height:78%!important;right:4%!important;top:8%!important;border-width:8px!important;}
  .landing-preview,.tips-preview{min-height:clamp(320px,44vw,460px)!important;}
  .landing-preview .landing-slider,.tips-preview .landing-slider{min-height:clamp(300px,42vw,440px)!important;}
}

/* 2026-06 precision fix: no safe-zone shrink, robust full-frame sliders.
   The fixed round buttons may float above the page, but content keeps its natural width. */
:root{--right-action-safe:0px!important;}
main > .section,
.hero,
.landing-hero,
.landing-content,
.about .inner,
.footer .inner,
.channel-card{
  padding-right:clamp(.85rem,3vw,1.2rem)!important;
}
.section-title,
.landing-copy,
.tips-copy,
.copy,
.contact-card,
.form,
.notice,
.service,
.work,
.gallery figcaption,
.landing-services,
.contact-wrap,
.service-grid,
.work-grid,
.gallery{
  max-width:none!important;
}
.actions,.tabs{padding-right:0!important;}

/* Make every slider a self-contained image viewport; no percent-height traps and no white gutters. */
.hero{overflow:hidden!important;}
.hero-art{
  position:relative!important;
  min-width:0!important;
  width:100%!important;
  min-height:clamp(360px,44vw,580px)!important;
  overflow:hidden!important;
}
.hero-slider{
  position:absolute!important;
  left:50%!important;
  top:50%!important;
  right:auto!important;
  bottom:auto!important;
  width:min(88%,560px)!important;
  height:auto!important;
  aspect-ratio:1/1!important;
  max-height:calc(100% - 18px)!important;
  transform:translate(-50%,-50%)!important;
  border-width:clamp(6px,.8vw,10px)!important;
  border-radius:44% 56% 42% 58%!important;
  overflow:hidden!important;
  background:transparent!important;
  z-index:2!important;
}
.hero-slider img,
.landing-slider img,
.landing-preview .landing-slider img,
.tips-preview .landing-slider img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  min-width:100%!important;
  min-height:100%!important;
  max-width:none!important;
  max-height:none!important;
  object-fit:cover!important;
  object-position:center center!important;
  display:block!important;
  margin:0!important;
  padding:0!important;
}

/* Landing/tips cards: the frame defines the ratio, the slider fills the frame. */
.landing-card.landing-preview,
.tips-preview{
  position:relative!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  height:auto!important;
  min-height:0!important;
  aspect-ratio:4 / 3!important;
  overflow:hidden!important;
  padding:.9rem!important;
  background:#fff!important;
}
.landing-preview .landing-slider,
.tips-preview .landing-slider,
.landing-slider{
  position:absolute!important;
  inset:.9rem!important;
  width:auto!important;
  height:auto!important;
  min-width:0!important;
  min-height:0!important;
  max-width:none!important;
  max-height:none!important;
  border:0!important;
  border-radius:14px!important;
  box-shadow:none!important;
  overflow:hidden!important;
  background:transparent!important;
}

/* Hide sliders only for real narrow/portrait one-column layouts. Landscape phones get the slider back immediately after rotation. */
@media (max-width:700px), (max-width:950px) and (orientation:portrait){
  .hero-art,
  .hero-slider,
  .landing-preview,
  .landing-slider,
  .tips-preview{display:none!important;}
  .hero,.landing-hero{grid-template-columns:1fr!important;min-height:auto!important;}
}
@media (orientation:landscape) and (max-width:1100px){
  .hero-art,
  .hero-slider,
  .landing-preview,
  .landing-slider,
  .tips-preview,
  .slider-wrap-hidden,
  .slider-wrap-hidden .hero-slider,
  .slider-wrap-hidden .landing-slider{display:block!important;}
  .hero.slider-row-wrapped,
  .landing-hero.slider-row-wrapped{grid-template-columns:minmax(0,1fr) minmax(180px,.72fr)!important;}
}
@media (orientation:landscape) and (max-width:950px) and (max-height:560px){
  .hero,.landing-hero{
    grid-template-columns:minmax(0,1fr) minmax(170px,.70fr)!important;
    gap:clamp(.55rem,1.8vw,1rem)!important;
    padding-right:.8rem!important;
  }
  .hero-art{min-height:clamp(190px,58vh,330px)!important;max-height:calc(100dvh - 112px)!important;}
  .hero-slider{width:min(90%,330px)!important;max-height:calc(100% - 12px)!important;border-width:6px!important;}
  .landing-card.landing-preview,.tips-preview{aspect-ratio:4/3!important;padding:.5rem!important;}
  .landing-preview .landing-slider,.tips-preview .landing-slider{inset:.5rem!important;border-radius:12px!important;}
}

/* Smaller fixed round buttons on narrow / portrait phones without reserving page width for them. */
@media (max-width:560px), (orientation:portrait) and (max-width:780px){
  .social-dock{right:6px!important;gap:.38rem!important;}
  .butterfly-ui{right:6px!important;}
  .social-dock a,
  .butterfly-toggle{
    width:34px!important;
    min-height:34px!important;
    border-width:2px!important;
    box-shadow:3px 3px 0 var(--pink)!important;
  }
  .social-dock span{font-size:.9rem!important;}
  .ig-glyph{width:1rem!important;height:1rem!important;}
}

/* Slightly quieter top bar text. */
.top{font-size:clamp(.64rem,.95vw,.78rem)!important;letter-spacing:.075em!important;}

/* 2026-06 final wrap guard: if JavaScript detects a slider would move into a new row,
   keep it hidden even in landscape overrides. This rule intentionally lives last. */
.hero-art.slider-wrap-hidden,
.landing-preview.slider-wrap-hidden,
.tips-preview.slider-wrap-hidden,
.slider-wrap-hidden .hero-slider,
.slider-wrap-hidden .landing-slider{
  display:none!important;
}
.hero.slider-row-wrapped,
.landing-hero.slider-row-wrapped{
  grid-template-columns:1fr!important;
  min-height:auto!important;
}
@media (orientation:landscape) and (max-width:1100px){
  .hero-art.slider-wrap-hidden,
  .landing-preview.slider-wrap-hidden,
  .tips-preview.slider-wrap-hidden,
  .slider-wrap-hidden .hero-slider,
  .slider-wrap-hidden .landing-slider{
    display:none!important;
  }
  .hero.slider-row-wrapped,
  .landing-hero.slider-row-wrapped{
    grid-template-columns:1fr!important;
  }
}

/* Kept from the former finishing pass: tips video and accessibility helpers. */
.tips-video{margin-top:2rem;border-radius:28px;background:#fff;box-shadow:var(--shadow);padding:clamp(12px,2vw,22px);border:2px solid rgba(255,58,140,.18)}
.tips-video iframe{display:block;width:100%;aspect-ratio:16/9;border:0;border-radius:20px;background:#111;}
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important;}

/* 2026-06 real fix: pink only for editable content-block headings, not global design headlines. */
.hero h1{color:inherit!important;}
.hero h1 .orange{color:var(--orange)!important;}
.hero h1 .lav{color:var(--lav)!important;}
.hero h1 .sage{color:var(--sage)!important;}
.landing-hero h1,
.section-title h2,
.contact-card h2,
.about h2,
.service h3,
.review-card strong,
.timeline-item strong{color:inherit!important;}
.copy h1,.copy h2,.copy h3,.copy h4,.copy h5,.copy h6,
.landing-copy h1,.landing-copy h2,.landing-copy h3,.landing-copy h4,.landing-copy h5,.landing-copy h6,
.tips-copy h1,.tips-copy h2,.tips-copy h3,.tips-copy h4,.tips-copy h5,.tips-copy h6,
.contact-wrap .copy h1,.contact-wrap .copy h2,.contact-wrap .copy h3,
.form .copy h1,.form .copy h2,.form .copy h3{color:var(--pink)!important;}
.timeline-wrap.timeline-no-line{display:block!important;}
.timeline-wrap.timeline-no-line .timeline-line,
.timeline-wrap.timeline-no-line .timeline-item:before{display:none!important;}
.timeline-wrap.timeline-no-line .timeline-list{display:grid!important;gap:.8rem!important;}

/* Final responsive/social dock polish 2026-06: keep butterfly control in the social stack and transparent inside the white round button. */
.butterfly-ui{
  z-index:2147483646!important;
  justify-items:stretch!important;
  align-items:start!important;
}
.butterfly-toggle{
  width:52px!important;
  height:52px!important;
  min-height:52px!important;
  border-radius:999px!important;
  background:#fff!important;
  color:var(--ink)!important;
  border:2px solid var(--ink)!important;
  box-shadow:6px 6px 0 var(--pink)!important;
  display:grid!important;
  place-items:center!important;
  padding:0!important;
  margin:0!important;
  overflow:visible!important;
  font-size:0!important;
  transition:transform .18s ease,background .18s ease,box-shadow .18s ease!important;
}
.butterfly-toggle:hover,.butterfly-ui.is-open .butterfly-toggle{
  transform:translateX(-4px) rotate(-4deg)!important;
  background:var(--lime)!important;
}
.butterfly-toggle::before{
  content:""!important;
  width:34px!important;
  height:34px!important;
  display:block!important;
  background:url('../assets/img/ui/butterfly-icon-purple-transparent.png') center/contain no-repeat!important;
  transform:none!important;
}
.butterfly-toggle::after{
  content:"Schmetterlinge"!important;
  position:absolute!important;
  right:62px!important;
  top:50%!important;
  transform:translateY(-50%)!important;
  background:var(--ink)!important;
  color:#fff!important;
  font-style:normal!important;
  font-size:.75rem!important;
  font-weight:900!important;
  padding:.35rem .55rem!important;
  border-radius:999px!important;
  opacity:0!important;
  pointer-events:none!important;
  white-space:nowrap!important;
  line-height:1.1!important;
}
.butterfly-toggle:hover::after,.butterfly-toggle:focus-visible::after{opacity:1!important;}
.butterfly-ui.is-open{
  position:fixed!important;
  left:50%!important;
  right:auto!important;
  top:8px!important;
  bottom:auto!important;
  transform:translateX(-50%)!important;
  width:min(340px,calc(100vw - 20px))!important;
  z-index:2147483647!important;
  justify-items:stretch!important;
}
.butterfly-ui.is-open .butterfly-toggle{justify-self:end!important;margin-bottom:.45rem!important;}
.butterfly-ui.is-open .butterfly-panel{
  display:block!important;
  width:100%!important;
  max-height:calc(100dvh - 78px)!important;
  overflow:auto!important;
}
@media(max-width:950px){
  .social-dock a,.butterfly-toggle{width:44px!important;height:44px!important;min-height:44px!important;box-shadow:4px 4px 0 var(--pink)!important;}
  .butterfly-toggle::before{width:29px!important;height:29px!important;}
  .butterfly-toggle::after{display:none!important;}
}
@media(max-width:560px),(orientation:portrait) and (max-width:700px){
  .social-dock a,.butterfly-toggle{width:36px!important;height:36px!important;min-height:36px!important;border-width:2px!important;box-shadow:3px 3px 0 var(--pink)!important;}
  .butterfly-toggle::before{width:24px!important;height:24px!important;}
}
.text-admin-tools input,.text-admin-tools select{max-width:100%;}

/* Final timeline cleanup: no stray vertical marker line on the right/after the last point. */
.timeline-line{display:none!important;}
.timeline-wrap{grid-template-columns:1fr!important;}
.timeline-item:before{display:none!important;}

/* 2026-06 frame fix: landing/tips slideshow cards must keep a visible white frame on all sides.
   The slider is the image viewport; the card owns the padding and must not clip its own frame. */
.landing-card.landing-preview,
.landing-card.tips-preview,
.tips-preview{
  box-sizing:border-box!important;
  display:block!important;
  overflow:visible!important;
  background:#fff!important;
  padding:clamp(10px,1.05vw,16px) clamp(10px,1.05vw,16px) clamp(24px,2.1vw,34px)!important;
  border-radius:22px!important;
}
.landing-card.landing-preview .landing-slider,
.landing-card.tips-preview .landing-slider,
.tips-preview .landing-slider{
  box-sizing:border-box!important;
  position:relative!important;
  display:block!important;
  inset:auto!important;
  width:100%!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  aspect-ratio:4/3!important;
  overflow:hidden!important;
  border:0!important;
  border-radius:16px!important;
  background:#fff!important;
  box-shadow:none!important;
  transform:none!important;
}
.landing-card.landing-preview .landing-slider img,
.landing-card.tips-preview .landing-slider img,
.tips-preview .landing-slider img{
  position:absolute!important;
  inset:0!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  object-fit:cover!important;
  object-position:center center!important;
  border-radius:0!important;
}
.landing-card.landing-preview .landing-slider img.active,
.landing-card.tips-preview .landing-slider img.active,
.tips-preview .landing-slider img.active,
.landing-card.landing-preview .landing-slider img:first-child,
.landing-card.tips-preview .landing-slider img:first-child,
.tips-preview .landing-slider img:first-child{opacity:1;}
@media (orientation:landscape) and (max-height:560px) and (max-width:980px){
  .landing-card.landing-preview,
  .landing-card.tips-preview,
  .tips-preview{padding:.5rem .5rem 1rem!important;border-radius:16px!important;}
  .landing-card.landing-preview .landing-slider,
  .landing-card.tips-preview .landing-slider,
  .tips-preview .landing-slider{aspect-ratio:16/10!important;border-radius:12px!important;}
}



/* Final clean layer: social dock + butterfly settings.
   Closed = normal social-dock item. Open = moved to body by JS and displayed above all bars. */
.social-dock{align-items:center!important;gap:14px!important;z-index:1200!important;}
.social-dock a,.butterfly-toggle{width:52px!important;height:52px!important;min-height:52px!important;border-radius:999px!important;background:#fff!important;color:var(--ink)!important;border:2px solid var(--ink)!important;box-shadow:6px 6px 0 var(--pink)!important;display:grid!important;place-items:center!important;box-sizing:border-box!important;transition:transform .18s ease,background .18s ease,box-shadow .18s ease!important;}
.social-dock a:hover,.butterfly-toggle:hover,.butterfly-ui.is-open .butterfly-toggle{transform:translateX(-4px) rotate(-4deg)!important;background:var(--lime)!important;}
.social-dock .butterfly-ui:not(.is-open){position:static!important;inset:auto!important;width:auto!important;height:auto!important;display:grid!important;place-items:center!important;z-index:auto!important;margin:0!important;transform:none!important;}
.butterfly-ui:not(.is-open) .butterfly-panel{display:none!important;}
.butterfly-toggle{position:relative!important;padding:0!important;margin:0!important;overflow:visible!important;font-size:0!important;line-height:1!important;}
.butterfly-toggle::before{content:""!important;width:34px!important;height:34px!important;display:block!important;background:url('../assets/img/ui/butterfly-icon-purple-transparent.png') center/contain no-repeat!important;transform:none!important;}
.butterfly-toggle::after{content:"Schmetterlinge"!important;position:absolute!important;right:62px!important;top:50%!important;transform:translateY(-50%)!important;background:var(--ink)!important;color:#fff!important;font-style:normal!important;font-size:.75rem!important;font-weight:900!important;padding:.35rem .55rem!important;border-radius:999px!important;opacity:0!important;pointer-events:none!important;white-space:nowrap!important;line-height:1.1!important;}
.butterfly-toggle:hover::after,.butterfly-toggle:focus-visible::after{opacity:1!important;}
body > .butterfly-ui.is-open{position:fixed!important;left:50%!important;right:auto!important;top:max(8px,env(safe-area-inset-top))!important;bottom:auto!important;transform:translateX(-50%)!important;width:min(420px,calc(100vw - 18px))!important;z-index:2147483647!important;display:grid!important;justify-items:stretch!important;align-items:start!important;isolation:isolate!important;}
body > .butterfly-ui.is-open .butterfly-toggle{justify-self:end!important;margin-bottom:.45rem!important;}
body > .butterfly-ui.is-open .butterfly-panel{display:block!important;width:100%!important;max-height:calc(100dvh - 74px)!important;overflow:auto!important;overscroll-behavior:contain!important;}
@media(max-width:950px){.social-dock{gap:12px!important}.social-dock a,.butterfly-toggle{width:44px!important;height:44px!important;min-height:44px!important;box-shadow:4px 4px 0 var(--pink)!important}.butterfly-toggle::before{width:29px!important;height:29px!important}.butterfly-toggle::after{display:none!important}}
@media(max-width:560px),(orientation:portrait) and (max-width:700px){.social-dock{gap:10px!important}.social-dock a,.butterfly-toggle{width:36px!important;height:36px!important;min-height:36px!important;border-width:2px!important;box-shadow:3px 3px 0 var(--pink)!important}.butterfly-toggle::before{width:24px!important;height:24px!important}}

/* 2026-06 visual spacing polish: cleaner home rhythm and shadowless slider frame. */
.hero{
  min-height:clamp(560px,58vw,690px)!important;
  padding-top:clamp(1.6rem,3vw,3rem)!important;
  padding-bottom:clamp(3.2rem,5vw,4.6rem)!important;
  gap:clamp(1.4rem,3.2vw,3rem)!important;
  align-items:center!important;
}
.hero > div:first-child{
  align-self:center!important;
  min-width:0!important;
}
.hero h1{
  margin:.45rem 0 .75rem!important;
}
.hero-copy-short p,
.hero .copy p{
  margin:0 0 1.05rem!important;
}
.hero-slider,
.hero-img{
  box-shadow:none!important;
}
.hero-slider{
  filter:none!important;
}
.home-after-hero{
  padding-top:clamp(1.35rem,2.4vw,2.1rem)!important;
  padding-bottom:clamp(1.65rem,2.8vw,2.8rem)!important;
}
.home-after-hero .copy{
  width:min(100%,1000px)!important;
  margin:0 auto!important;
  line-height:1.72!important;
}
.home-after-hero .copy p{
  margin:0 0 1.15rem!important;
}
.service-strip{
  margin-top:0!important;
  padding-top:clamp(3rem,4.2vw,4.2rem)!important;
  padding-bottom:clamp(3rem,4.2vw,4.2rem)!important;
  overflow:hidden!important;
}
.service-strip:before{
  top:-96px!important;
  height:104px!important;
}
.service-grid,
.landing-services .service-grid{
  width:min(100%,1240px)!important;
  max-width:1240px!important;
  margin-left:auto!important;
  margin-right:auto!important;
  grid-template-columns:repeat(auto-fit,minmax(min(230px,100%),1fr))!important;
  gap:clamp(1rem,1.8vw,1.35rem)!important;
}
.service{
  min-width:0!important;
  padding:clamp(.95rem,1.4vw,1.2rem)!important;
}
@media (min-width:1200px){
  .hero{
    grid-template-columns:minmax(0,.92fr) minmax(420px,1fr)!important;
  }
  .hero-art{
    min-height:clamp(500px,38vw,570px)!important;
  }
}
@media (max-width:950px){
  .hero{
    min-height:auto!important;
    padding-bottom:clamp(2.2rem,5vw,3.4rem)!important;
  }
  .home-after-hero{
    padding-top:1.4rem!important;
  }
  .service-strip:before{
    top:-72px!important;
    height:80px!important;
  }
}
@media (orientation:landscape) and (max-width:950px) and (max-height:560px){
  .hero{
    padding-top:.9rem!important;
    padding-bottom:1.8rem!important;
    gap:1rem!important;
  }
  .home-after-hero{
    padding-top:1rem!important;
    padding-bottom:1.3rem!important;
  }
  .service-strip{
    padding-top:2.4rem!important;
  }
}


/* 2026-06 final wave restore: keep the soft wave visible above the service bar. */
.service-strip{
  position:relative!important;
  z-index:1!important;
  overflow:visible!important;
  isolation:isolate!important;
}
.service-strip:before{
  content:""!important;
  position:absolute!important;
  left:50%!important;
  top:-104px!important;
  transform:translateX(-50%)!important;
  width:100vw!important;
  height:112px!important;
  background:var(--soft)!important;
  z-index:0!important;
  pointer-events:none!important;
  clip-path:polygon(0 50%,4% 42%,8% 52%,12% 40%,16% 52%,20% 41%,24% 53%,28% 42%,32% 52%,36% 40%,40% 51%,44% 41%,48% 53%,52% 42%,56% 52%,60% 40%,64% 52%,68% 41%,72% 53%,76% 42%,80% 52%,84% 40%,88% 51%,92% 42%,96% 52%,100% 41%,100% 100%,0 100%)!important;
}
.service-strip > *{
  position:relative!important;
  z-index:1!important;
}
@media(max-width:950px){
  .service-strip:before{top:-78px!important;height:86px!important;}
}


/* Final root/UX fix: creative-offer dropdown stays open while moving from parent to submenu. */
.nav-dropdown{position:relative!important;}
.nav-dropdown__menu{top:100%!important;margin-top:0!important;padding-top:.55rem!important;}
.nav-dropdown__menu::before{content:"";position:absolute;left:0;right:0;top:-12px;height:14px;}
.nav-dropdown:hover>.nav-dropdown__menu,.nav-dropdown:focus-within>.nav-dropdown__menu,.nav-dropdown.is-open>.nav-dropdown__menu{display:block!important;}
.nav-dropdown__menu a{cursor:pointer!important;}
@media (hover:hover) and (pointer:fine){.nav-dropdown>button{cursor:default;}}
@media(max-width:950px){.nav-dropdown__menu::before{display:none!important;}.nav-dropdown.is-open>.nav-dropdown__menu{display:block!important;}}

/* Chat media uploads: safe previews, compact controls and attachment cards */
.chat-attach-bar{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin:.45rem 0 .7rem}
.chat-file-button,.chat-voice-button{appearance:none;border:1px solid rgba(23,23,23,.14);background:rgba(255,255,255,.82);border-radius:999px;padding:.48rem .78rem;font:inherit;font-weight:800;cursor:pointer;box-shadow:0 6px 16px rgba(17,17,17,.08)}
.chat-file-button input{position:absolute;inline-size:1px;block-size:1px;opacity:0;pointer-events:none}
.chat-voice-button.recording{background:#fff0f6;border-color:#f9348b;color:#c01662;animation:pulseVoice 1s ease-in-out infinite}
@keyframes pulseVoice{50%{transform:scale(1.04)}}
.chat-file-preview{font-size:.82rem;line-height:1.35;max-width:100%;color:#5e5160;overflow:hidden;text-overflow:ellipsis}
.chat-attachments{display:grid;gap:.5rem;margin:.55rem 0 .25rem;max-width:min(100%,26rem)}
.chat-attachment{display:flex;align-items:center;gap:.65rem;border:1px solid rgba(23,23,23,.12);background:rgba(255,255,255,.78);border-radius:18px;padding:.52rem;color:inherit;text-decoration:none;box-shadow:0 8px 18px rgba(17,17,17,.07)}
.chat-attachment--image{display:grid;grid-template-columns:5.2rem 1fr;align-items:center}
.chat-attachment--image img{width:5.2rem;height:4rem;object-fit:cover;border-radius:13px;background:#fff}
.chat-attachment--file strong{display:grid;place-items:center;min-width:3.2rem;height:3.2rem;border-radius:13px;background:#f9348b;color:#fff;font-size:.85rem;letter-spacing:.04em}
.chat-attachment--audio{display:grid;gap:.3rem;padding:.62rem;border:1px solid rgba(23,23,23,.12);background:rgba(255,255,255,.78);border-radius:18px;box-shadow:0 8px 18px rgba(17,17,17,.07)}
.chat-attachment--audio audio{width:min(100%,18rem)}
.chat-scan-note{font-style:normal;font-size:.72rem;color:#7a6474;display:block;margin-top:.15rem}
@media (max-width:520px){.chat-attach-bar{gap:.4rem}.chat-file-button,.chat-voice-button{font-size:.86rem;padding:.42rem .62rem}.chat-attachment--image{grid-template-columns:4.3rem 1fr}.chat-attachment--image img{width:4.3rem;height:3.4rem}}

/* Chat upload preview: immediate image/audio/file preview before sending */
.chat-file-preview{display:block;flex:1 1 100%;min-width:min(100%,18rem);white-space:normal;overflow:visible;text-overflow:clip}
.chat-file-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(8.5rem,1fr));gap:.5rem;width:100%;margin-top:.3rem}
.chat-file-preview-card{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.45rem;border:1px solid rgba(23,23,23,.12);background:rgba(255,255,255,.86);border-radius:16px;padding:.45rem .55rem;box-shadow:0 7px 16px rgba(17,17,17,.06);min-width:0}
.chat-file-preview-card b{display:block;font-size:.78rem;line-height:1.18;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#423742}
.chat-file-preview-card small{grid-column:2;font-size:.68rem;color:#736673}
.chat-file-preview-card strong,.chat-file-preview-card>span:first-child{display:grid;place-items:center;width:2.3rem;height:2.3rem;border-radius:11px;background:#f9348b;color:#fff;font-size:.76rem;font-weight:800}
.chat-file-preview-card--image{grid-template-columns:3.4rem 1fr}
.chat-file-preview-card--image img{width:3.4rem;height:3.1rem;object-fit:cover;border-radius:11px;background:#fff}
.chat-file-preview-card--audio{grid-template-columns:2.4rem 1fr}
.chat-file-preview-card--audio audio{grid-column:1 / -1;width:100%;height:2rem}
.chat-voice-button.recording{box-shadow:0 0 0 4px rgba(249,52,139,.18);transform:translateY(-1px)}
@media (max-width:520px){.chat-file-preview-grid{grid-template-columns:1fr}.chat-file-preview-card{border-radius:14px}.chat-file-preview-card--image img{height:2.9rem}}

/* Final mobile portrait offer-page fit: keep creative-offer pages inside the viewport. */
@media (orientation: portrait) and (max-width: 900px){
  .landing-hero{
    width:100%!important;
    max-width:100vw!important;
    box-sizing:border-box!important;
    padding:1.35rem .9rem 2rem!important;
    gap:1rem!important;
    overflow:hidden!important;
  }
  .landing-hero > *{
    min-width:0!important;
    max-width:100%!important;
    box-sizing:border-box!important;
  }
  .landing-hero h1{
    font-size:clamp(2.55rem,13vw,4.45rem)!important;
    line-height:.92!important;
    overflow-wrap:anywhere!important;
    hyphens:auto!important;
  }
  .landing-hero p{
    max-width:100%!important;
    font-size:1rem!important;
    line-height:1.58!important;
  }
  .landing-card,
  .landing-preview{
    width:100%!important;
    max-width:calc(100vw - 1.8rem)!important;
    margin:.5rem auto 0!important;
    transform:none!important;
    box-sizing:border-box!important;
  }
  .landing-preview .landing-slider{
    width:100%!important;
    height:clamp(260px,62vw,390px)!important;
    min-height:clamp(260px,62vw,390px)!important;
  }
  .landing-content,
  .landing-copy,
  .landing-services,
  .work-grid{
    width:100%!important;
    max-width:100vw!important;
    box-sizing:border-box!important;
  }
}
@media (max-width: 700px) and (orientation: portrait){
  .landing-card,
  .landing-preview,
  .landing-preview .landing-slider{
    display:none!important;
  }
}

/* Parent photo release */
.release-page{width:min(1120px, calc(100% - 28px)); margin:0 auto 60px;}
.release-box{margin:18px 0;}
.release-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;align-items:stretch;}
.release-card{background:#fff;border:2px solid rgba(249,52,139,.2);border-radius:24px;padding:12px;box-shadow:0 10px 28px rgba(50,25,42,.08);}
.release-card img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:18px;border:4px solid #fff;box-shadow:0 4px 16px rgba(0,0,0,.08);}
.release-card h3{margin:.7rem 0 .35rem;}
.release-card label{display:block;margin:.45rem 0;font-weight:700;}
.release-card.is-revoked{opacity:.58;filter:grayscale(.2);}
.release-checks{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:12px 0;}
.release-checks label{background:rgba(255,255,255,.7);border:1px solid rgba(249,52,139,.18);border-radius:16px;padding:10px 12px;font-weight:800;}
.signature-pad{width:100%;height:220px;background:#fff;border:2px dashed rgba(249,52,139,.4);border-radius:18px;touch-action:none;display:block;margin:8px 0;}
@media(max-width:700px){.release-page{width:min(100% - 18px, 1000px)}.release-grid{grid-template-columns:1fr}.signature-pad{height:180px}}
.release-link-card{margin-top:28px;padding:22px;border-radius:24px;background:linear-gradient(135deg,rgba(249,52,139,.12),rgba(121,87,180,.10));border:1px solid rgba(249,52,139,.18)}
.release-link-card .btn{display:inline-flex;margin-top:8px;}

/* Parent photo release polish: mutually exclusive choices + robust signature field. */
.release-choice{display:grid;gap:.45rem;margin-top:.65rem;}
.release-choice label{border:1px solid rgba(249,52,139,.18);border-radius:14px;padding:.58rem .7rem;background:rgba(255,255,255,.72);}
.release-choice label:has(input:checked){background:rgba(249,52,139,.10);border-color:rgba(249,52,139,.45);}
.signature-pad{touch-action:none;-webkit-user-select:none;user-select:none;background:#fffdf8!important;}
.release-box .field small{display:block;margin:.25rem 0 0;color:rgba(27,20,32,.68);line-height:1.35;font-size:.82rem;}

/* Parent release upload UX: professional progress display and stable previews */
.upload-preview-slot{display:flex;flex-wrap:wrap;gap:.55rem;align-items:flex-start;margin-top:.55rem;min-height:42px;color:rgba(27,20,32,.62)}
.release-preview-thumb{display:grid;gap:.28rem;width:86px;min-width:0}
.release-preview-thumb img{width:86px;height:74px;object-fit:cover;border-radius:14px;border:3px solid #fff;box-shadow:0 8px 18px rgba(27,20,32,.10);background:#fff}
.release-preview-thumb small,.release-preview-more{font-size:.68rem;line-height:1.18;overflow:hidden;text-overflow:ellipsis;color:rgba(27,20,32,.72)}
.release-upload-status{margin:1rem 0;padding:1rem;border-radius:20px;background:linear-gradient(135deg,rgba(249,52,139,.10),rgba(121,87,180,.08));border:1px solid rgba(249,52,139,.18);box-shadow:0 10px 28px rgba(27,20,32,.06)}
.release-upload-status__head,.release-upload-file__meta{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.45rem}
.release-upload-status__head strong,.release-upload-file__meta strong{color:#1b1420;font-weight:900;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.release-upload-status__head span,.release-upload-file__meta span{font-size:.82rem;font-weight:800;color:rgba(27,20,32,.68);white-space:nowrap}
.release-upload-bar{height:11px;border-radius:999px;background:rgba(255,255,255,.85);border:1px solid rgba(249,52,139,.18);overflow:hidden;box-shadow:inset 0 1px 3px rgba(27,20,32,.08)}
.release-upload-bar span{display:block;width:0;height:100%;border-radius:inherit;background:linear-gradient(90deg,#f9348b,#ff8a36,#7957b4);transition:width .18s ease}
.release-upload-files{display:grid;gap:.65rem;margin-top:.9rem}
.release-upload-file{padding:.68rem .75rem;border-radius:16px;background:rgba(255,255,255,.72);border:1px solid rgba(27,20,32,.08)}
.release-upload-file.is-done{border-color:rgba(76,143,94,.28);background:rgba(233,247,238,.82)}
.release-upload-file.is-error{border-color:rgba(196,40,40,.35);background:rgba(255,238,238,.9)}
.signature-pad{cursor:crosshair;overscroll-behavior:contain;}
@media(max-width:700px){.release-preview-thumb{width:74px}.release-preview-thumb img{width:74px;height:64px}.release-upload-status__head,.release-upload-file__meta{align-items:flex-start;flex-direction:column;gap:.18rem}.release-upload-file__meta span{white-space:normal}}

/* Parent photo release final fixes: removable previews, stable signature layout, clear delete actions */
.release-upload-picker{display:grid;gap:.75rem;align-items:start;overflow:visible!important;}
.release-upload-picker input[type=file]{position:relative;z-index:2;max-width:100%;}
.release-page .upload-preview-slot{display:flex;flex-wrap:wrap;gap:.7rem;align-items:flex-start;min-height:0!important;width:auto!important;height:auto!important;max-width:100%;overflow:visible!important;padding:.75rem;border:2px dashed rgba(27,20,32,.18);border-radius:18px;background:#fffdf8;}
.release-preview-thumb{position:relative;width:104px;display:grid;gap:.3rem;padding:.35rem;border:1px solid rgba(27,20,32,.10);border-radius:16px;background:#fff;box-shadow:0 8px 20px rgba(27,20,32,.08);}
.release-preview-thumb img{width:92px;height:76px;object-fit:cover;border-radius:12px;border:0;box-shadow:none;}
.release-preview-thumb small{font-size:.68rem;line-height:1.16;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.release-preview-remove{border:0;border-radius:999px;background:#f4eee8;padding:.25rem .45rem;font-weight:800;font-size:.7rem;cursor:pointer;}
.release-delete-form{display:none!important;}
.release-delete-image{margin-top:.7rem;width:100%;}
.signature-field{display:grid;gap:.35rem;margin:.5rem 0;}
.signature-pad{height:220px!important;min-height:180px;box-sizing:border-box;}
@media(max-width:700px){.signature-pad{height:180px!important}.release-preview-thumb{width:92px}.release-preview-thumb img{width:80px;height:66px}}

/* Parent release: show clearly when a customer photo was imported into the public gallery. */
.release-card.is-in-gallery{border-color:rgba(123,146,94,.42);box-shadow:0 12px 30px rgba(123,146,94,.12);}
.release-gallery-status{margin:.55rem 0 .65rem;padding:.55rem .7rem;border-radius:14px;font-weight:900;font-size:.9rem;line-height:1.35;}
.release-gallery-status.is-live{background:rgba(123,146,94,.14);color:#607642;border:1px solid rgba(123,146,94,.28);}
.release-gallery-status.is-approved{background:rgba(249,52,139,.10);color:#c92470;border:1px solid rgba(249,52,139,.24);}
.release-gallery-status.is-removed{background:#fff1f0;color:#9f1d16;border:1px solid rgba(217,45,32,.22);}

/* Cookie consent: lightweight, first-visit layer. Analytics starts only after opt-in. */
.cookie-consent[hidden]{display:none!important}
.cookie-consent{position:fixed;inset:auto clamp(12px,3vw,28px) clamp(12px,3vw,28px) auto;z-index:2147483000;max-width:min(560px,calc(100vw - 24px));font-family:var(--font-body,Inter,system-ui,sans-serif)}
.cookie-consent__card{position:relative;background:rgba(255,255,255,.97);border:3px solid #fff;border-radius:28px 20px 32px 18px;box-shadow:0 22px 70px rgba(33,22,36,.22);padding:1.15rem;color:#2d1d2a;backdrop-filter:blur(14px)}
.cookie-consent__card h2{margin:0 2rem .45rem 0;color:var(--pink,#ff3a8c);font-size:1.35rem;line-height:1.1}
.cookie-consent__text{font-size:.95rem;line-height:1.5;margin-bottom:.8rem}.cookie-consent__text p{margin:.35rem 0}
.cookie-consent__close{position:absolute;top:.65rem;right:.75rem;width:34px;height:34px;border:0;border-radius:999px;background:#fff0f7;color:#2d1d2a;font-size:1.35rem;line-height:1;cursor:pointer}
.cookie-consent__settings{display:grid;gap:.65rem;margin:.85rem 0}.cookie-consent__settings[hidden]{display:none!important}
.cookie-option{display:flex;gap:.75rem;align-items:center;justify-content:space-between;border:1px solid rgba(255,58,140,.18);background:#fff7fb;border-radius:18px;padding:.75rem}.cookie-option p{margin:.2rem 0 0;font-size:.88rem;line-height:1.4}.cookie-option span{font-size:.82rem;color:#735b68}.cookie-option--toggle input{position:absolute;opacity:0;pointer-events:none}.cookie-option--toggle i{flex:0 0 50px;width:50px;height:28px;border-radius:999px;background:#e6dbe4;position:relative;transition:.2s}.cookie-option--toggle i:before{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;left:3px;top:3px;box-shadow:0 2px 8px rgba(0,0,0,.18);transition:.2s}.cookie-option--toggle input:checked+i{background:var(--pink,#ff3a8c)}.cookie-option--toggle input:checked+i:before{transform:translateX(22px)}
.cookie-consent__actions{display:flex;flex-wrap:wrap;gap:.55rem;align-items:center}.cookie-consent__actions .btn{margin:0}.cookie-consent__actions [data-cookie-save]{display:none}.cookie-consent.is-settings [data-cookie-save]{display:inline-flex}
@media(max-width:640px){.cookie-consent{left:10px;right:10px;bottom:10px;max-width:none}.cookie-consent__card{border-radius:22px;padding:1rem}.cookie-consent__actions{display:grid;grid-template-columns:1fr 1fr}.cookie-consent__actions .btn{width:100%;justify-content:center}.cookie-consent__actions [data-cookie-accept-all]{grid-column:1/-1}}
