:root{--red:#D4282F;--black:#111;--text:#222;--muted:#666;--line:#e8e8e8;--bg:#fff;--soft:#f5f5f5;--soft-dark:#efefef;--footer:#dddddd;--radius:22px;--shadow:0 20px 40px rgba(0,0,0,.06)}
*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:#fff}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}svg{display:block}.container{width:min(1180px,calc(100% - 40px));margin:0 auto}.narrow{width:min(860px,calc(100% - 40px));margin:0 auto}.narrow-left{width:min(920px,calc(100% - 40px));margin:0 auto}.site-header{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);z-index:50}.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:18px}.brand img{height:58px;width:auto}.nav{display:flex;gap:24px;font-size:14px;font-weight:700;letter-spacing:.04em}.nav a{opacity:.72}.nav a.active,.nav a:hover{opacity:1;color:var(--red)}.socials{display:flex;align-items:center;gap:12px}.social-btn{display:inline-flex;align-items:center;gap:10px;padding:11px 16px;border:1px solid var(--line);border-radius:999px;font-size:14px;font-weight:600;background:#fff;color:var(--black)}.social-btn svg{width:18px;height:18px}.menu-toggle{display:none;background:none;border:none;font-size:26px}.eyebrow{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:12px}.eyebrow.light{color:#fff}.mini-label{font-size:12px;font-weight:800;letter-spacing:.14em;color:#7a7a7a}.hero{padding:56px 0 30px}.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}.hero-copy h1{font-size:clamp(38px,5vw,72px);line-height:.95;letter-spacing:-.05em;margin:0 0 18px}.hero-copy p{font-size:20px;line-height:1.55;color:var(--muted);max-width:720px}.hero-actions{display:flex;gap:14px;margin-top:26px;flex-wrap:wrap}.hero-actions-center{justify-content:center}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;font-weight:700;border:1px solid var(--line);transition:.2s;background:#fff}.btn-primary{background:var(--red);color:#fff;border-color:var(--red)}.btn-light{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.38);backdrop-filter:blur(4px)}.btn-footer{background:#fff}.btn:hover{transform:translateY(-1px)}.hero-media img{border-radius:34px;box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover;width:100%}.section{padding:70px 0}.section-tight{padding-top:18px}.section-head{display:flex;justify-content:space-between;gap:20px;align-items:end;margin-bottom:28px}.section-head-stack{display:block}.section-head h2{font-size:clamp(28px,3vw,46px);margin:8px 0 0;letter-spacing:-.04em}.section-head p{max-width:560px;color:var(--muted);margin:0}.feature-grid,.card-grid,.testimonial-grid,.institution-grid,.blog-grid,.admin-cards{display:grid;gap:22px}.feature-grid{grid-template-columns:repeat(3,1fr)}.feature-card,.product-card,.testimonial-card,.blog-card,.panel,.admin-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}.feature-card img.icon{width:48px;height:48px;margin-bottom:14px}.feature-card h3,.product-card h3,.blog-card h3{margin:0 0 10px}.feature-card p,.product-card p,.blog-card p,.testimonial-card p{color:var(--muted);line-height:1.6}.full-image-banner{position:relative;min-height:380px;background:center/cover no-repeat}.full-image-banner__overlay{position:absolute;inset:0;background:rgba(0,0,0,.35)}.full-image-banner__content{position:relative;display:grid;place-items:center;min-height:380px;padding:30px;text-align:center}.full-image-banner__content h2{color:#fff;max-width:860px;font-size:clamp(32px,4vw,68px);line-height:.98;letter-spacing:-.04em;margin:0;text-shadow:0 10px 30px rgba(0,0,0,.25)}.card-grid{grid-template-columns:repeat(3,1fr)}.product-card{padding:18px}.product-card .thumb{aspect-ratio:1/1;border-radius:18px;background:#f7f7f7;overflow:hidden;margin-bottom:16px;display:flex;align-items:center;justify-content:center}.product-card .thumb img{width:100%;height:100%;object-fit:cover}.meta{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:14px}.institution-grid{grid-template-columns:1fr 1fr;align-items:center}.institution-grid .images{display:grid;grid-template-columns:1fr 1fr;gap:14px}.institution-grid .images img{border-radius:26px;aspect-ratio:4/5;object-fit:cover}.institution-kofi{align-items:center}.kofi-showcase{background:linear-gradient(180deg,#fff,#f4f4f4);border:1px solid var(--line);border-radius:36px;padding:20px;box-shadow:var(--shadow)}.kofi-showcase img{width:100%;max-width:280px;margin:0 auto;object-fit:contain}.testimonial-grid{grid-template-columns:repeat(2,1fr)}.site-footer{border-top:1px solid #cfcfcf;padding:52px 0;background:var(--footer)}.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:22px;align-items:start}.footer-grid h4{margin:0 0 12px}.footer-grid a,.footer-grid p{display:block;color:#444;margin:0 0 8px}.footer-logo{height:52px;width:auto;margin-bottom:12px}.footer-contact{text-align:left}.footer-contact-classic .footer-inline-link{display:inline-flex;align-items:center;gap:10px;margin:0 0 10px;color:#444;font-weight:500}.footer-contact-classic .footer-inline-link svg{width:18px;height:18px;flex:0 0 auto}.footer-contact-classic .footer-inline-link:hover{color:var(--black)}.footer-map{text-align:left}.footer-legal{text-align:left}.page-hero{padding:52px 0 24px}.page-hero h1{font-size:clamp(34px,4vw,58px);margin:0 0 12px;letter-spacing:-.04em}.page-hero p{max-width:760px;color:var(--muted);font-size:18px;line-height:1.6}.blog-grid{grid-template-columns:repeat(3,1fr)}.blog-card img{border-radius:18px;aspect-ratio:16/10;object-fit:cover;margin-bottom:14px}.blog-landing-hero{position:relative;min-height:520px;background:center/cover no-repeat;display:grid;place-items:center}.blog-landing-hero__overlay{position:absolute;inset:0;background:rgba(0,0,0,.48)}.blog-landing-hero__content{position:relative;text-align:center;color:#fff;padding:40px 0}.blog-landing-hero__content h1{font-size:clamp(34px,4.4vw,70px);line-height:1.03;letter-spacing:-.05em;max-width:980px;margin:0 auto}.blog-listing{background:#f3f3f3}.blog-list{display:grid;gap:18px}.blog-list-item{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start;padding:18px 0;border-top:1px solid #dfdfdf}.blog-list-item:first-child{border-top:none}.blog-list-thumb img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:4px}.blog-list-body h3{font-size:20px;letter-spacing:-.02em;margin:0 0 10px}.blog-list-body p{margin:0 0 10px;color:#555;line-height:1.55}.post-inline-meta{color:#777;font-size:14px}.article-page{padding:10px 0 80px}.article-header h1{font-size:clamp(40px,4.7vw,74px);line-height:.98;letter-spacing:-.05em;max-width:920px;margin:22px 0 16px}.article-excerpt{max-width:780px;font-size:18px;line-height:1.55;color:#444;margin:0 0 28px}.article-author-row{display:flex;align-items:center;gap:14px;margin-bottom:28px}.article-author-avatar{width:52px;height:52px;border-radius:999px;overflow:hidden;background:#f0f0f0;flex:0 0 auto}.article-author-avatar img{width:100%;height:100%;object-fit:cover}.article-hero-media img{width:100%;max-height:720px;object-fit:cover;margin:10px 0 38px}.article-content{max-width:920px}.article-content p{font-size:18px;line-height:1.72;color:#2b2b2b;margin:0 0 28px}.modal{position:fixed;inset:0;background:rgba(0,0,0,.56);display:none;align-items:center;justify-content:center;padding:22px;z-index:80}.modal.open,.modal.show{display:flex}.modal-box{background:#fff;max-width:980px;width:100%;border-radius:28px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr}.modal-gallery{background:#f7f7f7;padding:20px}.modal-gallery img{width:100%;aspect-ratio:1/1;object-fit:contain;border-radius:20px}.modal-content{padding:28px}.close-modal{position:absolute;top:18px;right:18px;border:none;border-radius:999px;width:42px;height:42px;background:#fff;font-size:24px}.admin-login{min-height:100vh;display:grid;place-items:center;background:#f4f4f4}.login-box{width:min(420px,calc(100% - 30px));background:#fff;border:1px solid var(--line);border-radius:26px;padding:28px;box-shadow:var(--shadow)}.login-help{display:grid;gap:6px;border:1px solid var(--line);border-radius:18px;padding:14px 16px;background:#fafafa;margin:0 0 16px}.input,textarea,select{width:100%;padding:14px 16px;border:1px solid #ddd;border-radius:14px;font:inherit;background:#fff}textarea{min-height:120px}.input-readonly{background:#fafafa;color:#444}.label{display:block;margin:0 0 8px;font-weight:700}.form-row{display:grid;gap:14px;margin-bottom:16px}.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;align-items:start}.admin-sidebar{background:#111;color:#fff;padding:24px;position:sticky;top:0;align-self:start;height:100vh}.admin-sidebar a{display:block;padding:12px 14px;border-radius:14px;color:#fff;opacity:.84}.admin-sidebar a:hover,.admin-sidebar a.active{background:rgba(255,255,255,.08);opacity:1}.admin-main{padding:28px;background:#f6f6f6;overflow-x:hidden}.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;color:#555}.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:18px;overflow:hidden}.table th,.table td{padding:14px;border-bottom:1px solid #eee;text-align:left;vertical-align:top}.flash{padding:14px 16px;border-radius:14px;margin:0 0 18px}.flash.success{background:#ebfff0;color:#185c28}.flash.error{background:#fff0f0;color:#8a1f1f}.muted{color:var(--muted)}.mobile-only{display:none}
@media (max-width:980px){.hero-grid,.institution-grid,.modal-box,.footer-grid,.admin-shell,.blog-list-item{grid-template-columns:1fr}.feature-grid,.card-grid,.blog-grid,.testimonial-grid{grid-template-columns:1fr 1fr}.admin-sidebar{position:relative;height:auto}.nav{display:none;position:absolute;top:82px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:18px 20px;flex-direction:column}.nav.open{display:flex}.menu-toggle{display:block}.socials{display:none}.blog-list-thumb img{border-radius:18px}.footer-map,.footer-contact,.footer-legal{text-align:left}}
@media (max-width:680px){.feature-grid,.card-grid,.blog-grid,.testimonial-grid{grid-template-columns:1fr}.container,.narrow,.narrow-left{width:min(100% - 24px,1180px)}.hero-copy p,.article-content p{font-size:17px}.brand img{height:48px}.section{padding:52px 0}.full-image-banner,.full-image-banner__content{min-height:300px}.blog-landing-hero{min-height:420px}.article-header h1{font-size:clamp(34px,10vw,52px)}.mobile-only{display:block}}

.gallery-admin-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:12px 0 8px}.gallery-admin-item,.inline-preview{border:1px solid var(--line);border-radius:14px;padding:8px;background:#fff}.gallery-admin-item img,.inline-preview img{width:100%;height:110px;object-fit:cover;border-radius:10px}.product-thumb-carousel,.modal-gallery{position:relative}.thumb-nav,.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border:none;border-radius:999px;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;box-shadow:none;cursor:pointer;z-index:2;color:#111;transition:background .2s ease, opacity .2s ease}.thumb-nav.prev,.carousel-nav.prev{left:10px}.thumb-nav.next,.carousel-nav.next{right:10px}.thumb-nav:hover,.carousel-nav:hover{background:rgba(255,255,255,.34)}
.thumb-dots,.carousel-dots{position:absolute;left:0;right:0;bottom:10px;display:flex;justify-content:center;gap:8px;z-index:2}.thumb-dots button,.carousel-dots button{width:8px;height:8px;border-radius:999px;border:none;background:rgba(0,0,0,.2);padding:0;cursor:pointer}.thumb-dots button.active,.carousel-dots button.active{background:var(--red)}.testimonial-card{position:relative}.testimonial-avatar{width:58px;height:58px;border-radius:999px;overflow:hidden;margin-bottom:14px;background:#f2f2f2}.testimonial-avatar img{width:100%;height:100%;object-fit:cover}.article-inline-image{margin:10px 0 32px}.article-inline-image img{width:100%;border-radius:24px;object-fit:cover}.footer-grid-3{grid-template-columns:1fr 1fr 1fr}@media (max-width:980px){.gallery-admin-grid{grid-template-columns:repeat(3,1fr)}.footer-grid-3{grid-template-columns:1fr}}@media (max-width:680px){.gallery-admin-grid{grid-template-columns:repeat(2,1fr)}}

.kofi-page-chat{padding-top:24px}
.kofi-chat-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:start}
.kofi-showcase-small{margin-top:22px;max-width:280px}
.kofi-chat-shell{background:#fff;border:1px solid var(--line);border-radius:32px;overflow:hidden;box-shadow:var(--shadow)}
.kofi-chat-shell__header{display:flex;align-items:center;gap:14px;padding:18px 22px;border-bottom:1px solid var(--line)}
.kofi-chat-shell__avatar{width:54px;height:54px;object-fit:contain;flex:0 0 auto}
.kofi-chat-shell__header strong{display:block;font-size:18px;letter-spacing:-.02em}
.kofi-chat-shell__header span{display:block;margin-top:4px;color:var(--muted);font-size:14px;line-height:1.45}
.kofi-chat-shell iframe{display:block;width:100%;height:760px;border:0;background:#fff}
@media (max-width: 980px){.kofi-chat-layout{grid-template-columns:1fr}.kofi-showcase-small{max-width:220px}.kofi-chat-shell iframe{height:640px}}
@media (max-width: 640px){.kofi-chat-shell{border-radius:24px}.kofi-chat-shell__header{padding:16px 16px}.kofi-chat-shell iframe{height:560px}}


.kofi-page-redesign{padding:38px 0 74px}
.kofi-hero-grid{display:grid;grid-template-columns:minmax(320px,.86fr) minmax(0,1.14fr);gap:28px;align-items:stretch}
.kofi-intro-card{background:linear-gradient(180deg,#fff,#f7f7f7);border:1px solid var(--line);border-radius:32px;padding:32px;box-shadow:var(--shadow);display:flex;flex-direction:column;min-height:100%}
.kofi-intro-card h1{font-size:clamp(34px,4vw,58px);line-height:.98;letter-spacing:-.05em;margin:0 0 14px}
.kofi-lead{font-size:18px;line-height:1.6;color:var(--muted);margin:0 0 18px}
.kofi-intro-copy{display:grid;gap:14px}
.kofi-intro-copy p{margin:0;color:#3d3d3d;line-height:1.7}
.kofi-inline-meta{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 24px}
.kofi-inline-meta span{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border:1px solid var(--line);border-radius:999px;font-size:13px;font-weight:700;background:#fff}
.kofi-mascot-wrap{margin-top:auto;display:flex;justify-content:center;align-items:flex-end;padding-top:12px}
.kofi-mascot-wrap img{width:min(100%,360px);max-height:420px;object-fit:contain}
.kofi-chat-shell-page{min-height:780px}
.kofi-chat-shell-page iframe{height:calc(100% - 92px);min-height:688px}
@media (max-width: 980px){.kofi-page-redesign{padding-top:24px}.kofi-hero-grid{grid-template-columns:1fr}.kofi-intro-card{padding:26px}.kofi-mascot-wrap img{width:min(100%,260px);max-height:300px}.kofi-chat-shell-page{min-height:680px}.kofi-chat-shell-page iframe{min-height:580px}}
@media (max-width: 640px){.kofi-intro-card{border-radius:24px;padding:22px}.kofi-intro-card h1{font-size:34px}.kofi-lead{font-size:16px}.kofi-inline-meta span{font-size:12px;padding:9px 12px}.kofi-chat-shell-page{border-radius:24px;min-height:620px}.kofi-chat-shell-page iframe{min-height:520px}}


/* Kófi page clean layout */
.kofi-page-clean{padding:34px 0 72px}
.kofi-page-head{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:28px;align-items:center;margin-bottom:26px}
.kofi-page-copy{max-width:760px}
.kofi-page-copy h1{font-size:clamp(34px,4vw,60px);line-height:.98;letter-spacing:-.05em;margin:0 0 14px}
.kofi-copy-stack{display:grid;gap:12px;color:var(--muted);max-width:760px}
.kofi-page-mascot{display:flex;justify-content:center;align-items:flex-end}
.kofi-page-mascot img{width:min(100%,220px);max-height:240px;object-fit:contain}
.kofi-chat-large-card{background:#fff;border:1px solid var(--line);border-radius:32px;overflow:hidden;box-shadow:var(--shadow)}
.kofi-chat-large-card iframe{display:block;width:100%;height:820px;border:0;background:#fff}
@media (max-width: 980px){.kofi-page-head{grid-template-columns:1fr;gap:18px}.kofi-page-mascot{justify-content:flex-start}.kofi-page-mascot img{width:170px;max-height:190px}.kofi-chat-large-card iframe{height:760px}}
@media (max-width: 640px){.kofi-page-clean{padding-top:22px}.kofi-page-copy h1{font-size:36px}.kofi-chat-large-card{border-radius:24px}.kofi-chat-large-card iframe{height:680px}}


.section-instagram-home{padding-top:32px}
.instagram-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.instagram-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:var(--shadow);min-height:100%}.instagram-card:hover{transform:translateY(-2px)}.instagram-card__media{position:relative;aspect-ratio:4/5;background:#f6f6f6;border-bottom:1px solid var(--line);overflow:hidden}.media-carousel__stage{width:100%;height:100%}.media-carousel__stage img,.media-carousel__stage video{width:100%;height:100%;object-fit:cover;background:#000}.instagram-card__body{padding:18px 20px 20px;display:grid;gap:12px}.instagram-card__body h3{margin:0;font-size:18px;letter-spacing:-.02em}.instagram-card__body p{margin:0;color:var(--muted);line-height:1.6}.instagram-card__cta{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--black)}.instagram-card__cta svg{width:18px;height:18px}.media-carousel .thumb-nav{background:rgba(255,255,255,.14)}.media-carousel .thumb-dots{bottom:12px}.media-carousel .thumb-dots button{background:rgba(255,255,255,.55)}.media-carousel .thumb-dots button.active{background:#fff}.media-carousel video{display:block}
@media (max-width:1180px){.instagram-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:680px){.instagram-grid{grid-template-columns:1fr}}

.alert{padding:14px 16px;border-radius:14px;margin:0 0 18px;background:#f4f4f5;color:#111}.alert-error{background:#fef2f2;color:#991b1b}.alert-success{background:#f0fdf4;color:#166534}.store-shell,.checkout-grid,.auth-grid,.account-grid{display:grid;gap:24px}.cart-layout,.checkout-grid,.auth-grid,.account-grid{grid-template-columns:2fr 1fr}.auth-card,.cart-summary,.empty-state{background:#fff;border:1px solid #ececec;border-radius:24px;padding:24px;box-shadow:0 8px 24px rgba(0,0,0,.04)}.auth-card-wide{grid-column:span 2}.auth-form{display:grid;gap:14px}.auth-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.auth-form label{display:grid;gap:8px;font-size:14px;color:#111}.input{width:100%;padding:12px 14px;border:1px solid #d4d4d8;border-radius:14px;background:#fff}.form-actions{grid-column:span 2}.cart-items{display:grid;gap:14px}.cart-item{display:grid;grid-template-columns:92px 1.5fr 180px 120px 100px;gap:16px;align-items:center;background:#fff;border:1px solid #ececec;border-radius:20px;padding:16px}.cart-item img{width:92px;height:92px;object-fit:cover;border-radius:16px;border:1px solid #eee}.cart-item-actions{display:grid;gap:10px}.summary-line{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid #eee}.summary-total{font-size:18px;border-bottom:0;padding-top:16px}.small{font-size:12px}.product-card__actions{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-top:14px}.product-card__actions form{margin:0}.socials-store{display:flex;gap:10px;align-items:center}.checkout-note{margin-top:16px;font-size:13px;color:#6b7280}.order-list{display:grid;gap:12px}.order-card{display:grid;grid-template-columns:1.1fr .9fr .8fr auto;gap:12px;align-items:center;border:1px solid #ececec;border-radius:18px;padding:14px}.btn-ghost{background:#fff;border:1px solid #d4d4d8;color:#111}.empty-state{text-align:center}.empty-state .btn{margin-top:10px}
@media (max-width: 960px){.cart-layout,.checkout-grid,.auth-grid,.account-grid{grid-template-columns:1fr}.auth-card-wide,.form-actions{grid-column:auto}.auth-form-grid{grid-template-columns:1fr}.cart-item,.order-card{grid-template-columns:1fr}.socials-store{display:none}}

/* 2026-03 store refinements */
.nav-wrap{gap:18px}.nav{flex-wrap:wrap;justify-content:center}.social-btn svg,.footer-inline-link svg{width:20px;height:20px;flex:0 0 20px}.social-btn{display:inline-flex;align-items:center;gap:10px}.btn-dark{background:#111;color:#fff;border-color:#111}.btn-dark:hover{background:#222}
.card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.product-card{padding:18px;border-radius:24px}.product-card .thumb{aspect-ratio:1/1;border-radius:20px;overflow:hidden;background:#f7f7f7;cursor:pointer}.product-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}.product-card h3{font-size:clamp(20px,1.5vw,28px)}.product-card p{font-size:15px}.product-card__actions{flex-wrap:wrap;justify-content:flex-start}.product-card__actions .btn{font-size:13px;padding:10px 14px}.product-card__actions form{display:flex}
.testimonial-grid{margin-bottom:20px}.testimonial-cta{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 24px;border:1px solid var(--line);border-radius:24px;background:#fff;box-shadow:var(--shadow)}.testimonial-cta p{margin:6px 0 0;color:var(--muted)}
.footer-contact-classic{display:flex;flex-direction:column;align-items:flex-start;gap:10px}.footer-inline-link{display:inline-flex;align-items:center;gap:12px;line-height:1.2}.footer-inline-link span{display:inline-block}.footer-contact-classic p{margin:0}.footer-contact-classic .footer-inline-link:first-of-type{margin-bottom:2px}
.modal-actions{display:flex;flex-wrap:wrap;gap:12px}.modal-actions form{margin:0}
.cart-layout{align-items:start;gap:26px}.cart-items{gap:16px}.cart-item{grid-template-columns:88px minmax(0,1.3fr) 120px 110px auto;border-radius:24px;padding:18px}.cart-item h3{margin:0 0 6px}.cart-line-total{font-weight:800;font-size:18px}.cart-summary{position:sticky;top:110px;border-radius:24px}.checkout-grid{align-items:start}.checkout-grid .auth-card,.checkout-grid .cart-summary{border-radius:28px;padding:26px}.auth-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-form-grid label:nth-child(1),.auth-form-grid label:nth-child(2),.auth-form-grid label:nth-child(3),.auth-form-grid label:nth-child(4),.auth-form-grid label:nth-child(5),.auth-form-grid label:nth-child(6),.auth-form-grid label:nth-child(7),.auth-form-grid label:nth-child(8),.auth-form-grid label:nth-child(9),.auth-form-grid label:nth-child(10),.auth-form-grid label:nth-child(11),.auth-form-grid label:nth-child(12),.auth-form-grid label:nth-child(13){min-width:0}
@media (max-width:980px){.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.testimonial-cta{flex-direction:column;align-items:flex-start}.cart-item{grid-template-columns:1fr}}
@media (max-width:640px){.card-grid{grid-template-columns:1fr}.product-card__actions .btn{width:100%;justify-content:center}.product-card__actions form{width:100%}.footer-inline-link{align-items:flex-start}}


/* Checkout transparente v2 */
.payment-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:24px;align-items:start}
.payment-card-shell{border-radius:30px;padding:28px}
.payment-header-inline{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}
.payment-header-inline h2{margin:4px 0 8px;font-size:30px;letter-spacing:-.04em}
.payment-badge{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:999px;background:#111;color:#fff;font-weight:800;white-space:nowrap}
.payment-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.payment-grid-span-2{grid-column:span 2}
.mp-field{min-height:48px;border:1px solid #d4d4d8;border-radius:14px;background:#fff;padding:12px 14px;display:flex;align-items:center}
#form-checkout__cardNumber,#form-checkout__expirationDate,#form-checkout__securityCode{padding:0 14px}
.payment-submit-row{display:grid;gap:10px;align-items:center}
.payment-submit-row .btn{min-height:52px}
.payment-feedback{margin-top:18px;padding:14px 16px;border-radius:18px;background:#f5f5f5;border:1px solid #e4e4e7}
.payment-feedback.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.payment-feedback.success{background:#f0fdf4;border-color:#bbf7d0;color:#166534}
.payment-order-meta{display:grid;gap:10px;margin-top:18px;font-size:14px;color:#444}
.payment-inline-state{padding:10px 0;text-align:left}
.order-card__actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.btn-sm{padding:10px 14px;font-size:13px}
@media (max-width: 980px){.payment-layout{grid-template-columns:1fr}.payment-form-grid{grid-template-columns:1fr}.payment-grid-span-2{grid-column:auto}.payment-header-inline{flex-direction:column}.payment-badge{align-self:flex-start}.order-card__actions{justify-content:flex-start}}


/* v2.1 */
.mp-field{height:56px;min-height:56px;padding:0 14px;overflow:hidden}
.mp-field iframe{width:100% !important;height:54px !important;min-height:54px !important}
.payment-form-grid .input{min-height:56px}
.product-thumb-carousel{cursor:pointer;user-select:none}
.toast-container{position:fixed;right:18px;bottom:18px;z-index:9999;display:grid;gap:10px;pointer-events:none}
.toast{min-width:280px;max-width:360px;background:#111;color:#fff;padding:14px 16px;border-radius:16px;box-shadow:0 20px 45px rgba(0,0,0,.18);opacity:0;transform:translateY(12px);transition:all .22s ease}
.toast.show{opacity:1;transform:translateY(0)}
.toast.success{background:#111}
.toast.error{background:#8a1f1f}
.account-form{display:grid;gap:14px}
.account-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.account-form-grid .full{grid-column:1/-1}
.account-note{font-size:13px;color:var(--muted)}
@media (max-width:780px){.account-form-grid{grid-template-columns:1fr}.toast-container{left:12px;right:12px;bottom:12px}.toast{min-width:0;max-width:none}}


.product-thumb-carousel, .js-open-product { cursor:pointer; }
.coupon-form{display:grid;grid-template-columns:1fr auto;gap:10px;margin:14px 0;}
.discount-line strong{color:#c82828}
.footer-grid-3{grid-template-columns:1.1fr .8fr .9fr .9fr;}
.footer-legal{display:flex;flex-direction:column;gap:8px}
.footer-legal a{color:inherit;text-decoration:none;opacity:.86}
.footer-legal a:hover{opacity:1}
.site-coupon-banner{background:#f6efe8;border-bottom:1px solid #eadccf;font-size:14px}
.site-coupon-banner .container{display:flex;gap:14px;align-items:center;justify-content:center;padding:10px 20px;flex-wrap:wrap}
.coupon-modal .modal-box{max-width:980px;padding:0;overflow:hidden}
.coupon-modal-box{display:grid;grid-template-columns:1fr 1fr;background:#fff}
.coupon-modal-media img{width:100%;height:100%;object-fit:cover;display:block;min-height:420px}
.coupon-modal-content{padding:42px;display:flex;flex-direction:column;justify-content:center;gap:14px}
.coupon-badge{display:inline-flex;align-self:flex-start;background:#111;color:#fff;padding:8px 12px;border-radius:999px;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.coupon-code-box{padding:14px 16px;border:1px dashed #d4282f;border-radius:16px;background:#fff7f6}
.coupon-popup-form{display:flex;gap:10px;flex-wrap:wrap}
.freight-terms-inline{margin:8px 0 14px}
.btn-link{padding:0;border:none;background:none;color:#7a5a45;text-decoration:underline;box-shadow:none}
.freight-modal-box,.legal-layout{max-width:920px}
.modal-content-full{padding-right:22px}
.legal-richtext{line-height:1.7;color:#444;white-space:normal}
.legal-hero-image img{width:100%;max-height:460px;object-fit:cover;border-radius:28px;margin-bottom:20px}
.gallery-admin-item{position:relative}
.gallery-admin-item img{width:100%;height:140px;object-fit:cover;border-radius:14px;border:1px solid #eee}
@media (max-width: 900px){.coupon-modal-box{grid-template-columns:1fr}.coupon-modal-media img{min-height:220px}.footer-grid-3{grid-template-columns:1fr}}

body.modal-is-open{overflow:hidden}
.koffie-chat-root{z-index:70!important}.koffie-launcher-mascot{width:52px!important;left:10px!important;bottom:4px!important}.koffie-chat-button{min-width:170px!important;min-height:40px!important;padding:0 18px 0 72px!important;font-size:13px!important}.koffie-chat-button span{max-width:94px;line-height:1.1;text-align:left}.modal{z-index:120}.coupon-modal,.freight-modal{z-index:125}.product-card .thumb img,.product-thumb-carousel img{object-fit:contain;background:#f7f7f7}.footer-signature{margin-top:18px;padding-top:14px;border-top:1px solid #e5e5e5;color:#666;font-size:13px}.cookie-banner{position:fixed;left:18px;right:18px;bottom:18px;z-index:95;background:#5b2a7d;color:#fff;border-radius:22px;box-shadow:0 20px 40px rgba(0,0,0,.18);padding:18px 20px}.cookie-banner[hidden]{display:none}.cookie-banner__inner{display:grid;grid-template-columns:1.8fr auto;gap:18px;align-items:center}.cookie-banner__text strong{display:block;margin-bottom:6px;font-size:18px}.cookie-banner__text p{margin:0;color:rgba(255,255,255,.88);line-height:1.6}.cookie-banner__actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.btn-cookie-light{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.24);color:#fff}.payment-methods{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 10px}.payment-method-toggle{border:1px solid var(--line);background:#fff;color:#111;border-radius:999px;padding:10px 14px;font-weight:700;cursor:pointer}.payment-method-toggle.active{background:#111;color:#fff;border-color:#111}.payment-panel{display:none}.payment-panel.active{display:block}.payment-security{margin-top:18px;border:1px solid #ececec;border-radius:20px;padding:16px;background:#fafafa}.payment-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.payment-badge-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid #e4e4e7;font-size:13px;font-weight:700}.pix-box{display:grid;gap:14px}.pix-code{width:100%;min-height:110px;border:1px solid #ddd;border-radius:16px;padding:14px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.5;background:#fff}.pix-copy{display:flex;gap:10px;flex-wrap:wrap}.payment-qr img{width:180px;height:180px;object-fit:contain;border:1px solid #eee;border-radius:18px;background:#fff;padding:10px}.developer-credit{font-size:12px;color:#777;margin-top:10px}@media (max-width:980px){.cookie-banner__inner{grid-template-columns:1fr}.cookie-banner__actions{justify-content:flex-start}}@media (max-width:640px){.koffie-chat-button{min-width:140px!important;padding-left:64px!important}.koffie-launcher-mascot{width:44px!important}.cookie-banner{left:12px;right:12px;bottom:12px;padding:16px}.payment-qr img{width:150px;height:150px}}


/* v2.3.1 adjustments */
.footer-signature{margin-top:12px;padding:10px 20px 0;border-top:1px solid #e8e8e8;color:#8a8a8a;font-size:11px;text-align:center;display:flex;justify-content:center}.developer-credit{display:none}
.coupon-applied-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}.coupon-badge{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#fff5f5;border:1px solid rgba(213,40,47,.18);color:#9f1d22;font-size:13px;font-weight:700}.btn-sm{padding:9px 14px;font-size:13px}
.cookie-banner{background:#d4282f;color:#fff}.cookie-banner__text p{color:rgba(255,255,255,.92)}.btn-cookie-light{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.32);color:#fff}.btn-cookie-solid{background:#fff!important;border-color:#fff!important;color:#d4282f!important}
.koffie-chat-root{z-index:85!important}.koffie-launcher-mascot{width:44px!important;left:8px!important;bottom:2px!important}.koffie-chat-button{min-width:122px!important;min-height:36px!important;padding:0 14px 0 54px!important;font-size:12px!important;border-radius:999px!important}.koffie-chat-button span{max-width:62px;line-height:1.05;text-align:left}.modal,.coupon-modal,.freight-modal{z-index:140}
@media (max-width:640px){.coupon-applied-row{align-items:flex-start;flex-direction:column}.koffie-chat-button{min-width:108px!important;padding-left:50px!important;font-size:11px!important}.koffie-launcher-mascot{width:38px!important}}


/* v2.3.5 modal, trust and kofi */
.freight-modal{align-items:center;justify-content:center;padding:20px}
.freight-modal .modal-box,.freight-modal-box{display:block!important;width:min(980px,calc(100vw - 32px));max-width:min(980px,calc(100vw - 32px));max-height:86vh;overflow:auto;position:relative;border-radius:28px;padding:0}
.freight-modal .modal-content-full{padding:28px 28px 24px}
.freight-modal .close-modal{position:sticky;top:14px;float:right;z-index:2;margin:14px 14px 0 0}
.legal-richtext{max-width:100%;overflow-wrap:anywhere;word-break:normal;line-height:1.75}
.legal-richtext p,.legal-richtext ul,.legal-richtext ol{margin:0 0 16px}
.payment-trust-strip{margin-top:18px;padding:14px 16px;border:1px solid #ececec;border-radius:20px;background:#fafafa}
.payment-trust-label{display:block;font-size:13px;font-weight:800;color:#555;margin-bottom:10px;text-transform:uppercase;letter-spacing:.08em}
.payment-logo-list{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.payment-logo-list img{height:32px;width:auto;display:block}
.payment-security .payment-logo-list{margin-top:12px}
.koffie-chat-root{z-index:100!important;bottom:112px!important;right:18px!important}
.koffie-launcher-mascot{display:none!important}
.koffie-chat-button{width:170px!important;min-width:170px!important;height:72px!important;min-height:72px!important;padding:0!important;border:none!important;border-radius:0!important;background:transparent url('../img/kofi_chat_novo.png') center/contain no-repeat!important;box-shadow:none!important}
.koffie-chat-button span{opacity:0!important;max-width:0!important;width:0!important;overflow:hidden!important}
@media (max-width:640px){.freight-modal .modal-box,.freight-modal-box{width:calc(100vw - 20px);max-width:calc(100vw - 20px);max-height:88vh}.freight-modal .modal-content-full{padding:22px 18px 20px}.payment-logo-list img{height:28px}.koffie-chat-root{bottom:96px!important;right:10px!important}.koffie-chat-button{width:144px!important;min-width:144px!important;height:62px!important;min-height:62px!important}}

.payment-security .payment-trust-strip{margin-top:0;background:transparent;border:none;padding:0}
.payment-shared-form{margin-top:14px}
.payment-shared-form-note{padding:0 4px 8px}
.freight-modal{backdrop-filter:blur(2px)}

/* v2.3.6 refinements */
.product-card__actions{gap:8px}
.product-card__actions form{display:flex}
.product-card__actions .btn{min-height:40px}
.koffie-chat-root{bottom:112px!important;right:16px!important}
.koffie-chat-button{width:170px!important;min-width:170px!important;height:72px!important;min-height:72px!important;background:transparent url('../img/kofi_chat_novo.png') center/contain no-repeat!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:0!important}
.koffie-chat-button span{opacity:0!important;max-width:0!important;width:0!important;overflow:hidden!important}
.koffie-launcher-mascot{display:none!important}
@media (max-width:640px){.koffie-chat-root{bottom:96px!important;right:10px!important}.koffie-chat-button{width:138px!important;min-width:138px!important;height:58px!important;min-height:58px!important}}


/* v2.3.8 kofi + product card alignment */
.product-card{display:flex;flex-direction:column;height:100%}
.product-card h3{min-height:2.35em}
.product-card p{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:3.2em;margin-bottom:10px}
.product-card .meta{margin-top:auto;align-items:flex-end}
.product-card__actions{display:flex;gap:10px;align-items:flex-end;margin-top:12px;flex-wrap:nowrap}
.product-card__actions .btn{padding:11px 16px;font-size:14px;min-height:40px;white-space:nowrap}
.product-card__actions form{display:flex}
.koffie-chat-root{z-index:100!important;right:18px!important;bottom:86px!important}
.koffie-chat-button{width:154px!important;min-width:154px!important;height:229px!important;min-height:229px!important;background:transparent url('../img/kofi_chat_novo.png') center/contain no-repeat!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:0!important;display:block!important;opacity:1!important;visibility:visible!important}
.koffie-chat-button span{opacity:0!important;max-width:0!important;width:0!important;overflow:hidden!important}
.koffie-launcher-mascot{display:none!important}
@media (max-width:640px){.koffie-chat-root{right:8px!important;bottom:72px!important}.koffie-chat-button{width:118px!important;min-width:118px!important;height:176px!important;min-height:176px!important}.product-card__actions{gap:8px;flex-wrap:wrap}.product-card__actions .btn{padding:10px 14px;font-size:13px;min-height:36px}}


.site-footer-redesign{padding:0;background:#f2efeb;border-top:1px solid #e7dfd7}
.footer-newsletter{background:var(--red);color:#fff;padding:34px 0 30px;position:relative;overflow:visible}
.footer-newsletter__grid{position:relative;display:grid;grid-template-columns:minmax(230px,360px) 1fr;gap:34px;align-items:center;min-height:126px}
.footer-newsletter__beans{position:relative;min-height:150px;pointer-events:none}
.footer-newsletter__beans img{position:absolute;left:18px;top:-68px;width:210px;max-width:none;height:auto;display:block;filter:drop-shadow(0 8px 18px rgba(0,0,0,.14))}
.footer-newsletter__content{text-align:left;max-width:720px;padding-right:12px}
.footer-newsletter__content h3{margin:0 0 8px;font-size:32px;letter-spacing:-.04em;color:#fff}
.footer-newsletter__content p{margin:0 0 16px;color:rgba(255,255,255,.9);font-size:18px}
.newsletter-form{display:flex;gap:12px;justify-content:flex-start;align-items:center;flex-wrap:nowrap}
.newsletter-form input{flex:1;min-width:0;padding:14px 12px;border:none;border-bottom:2px solid rgba(255,255,255,.5);background:transparent;color:#fff;font:inherit;border-radius:0}
.newsletter-form input::placeholder{color:rgba(255,255,255,.78)}
.newsletter-form .btn{background:transparent;border:1px solid rgba(255,255,255,.55);color:#fff;padding:12px 22px;border-radius:999px;min-width:122px}
.footer-main{background:#ece8e2;color:#222;padding:40px 0 34px}
.footer-grid-redesign{grid-template-columns:1.2fr .8fr .95fr .95fr;gap:34px}
.footer-grid-redesign h4{color:#111;margin-bottom:14px}
.footer-grid-redesign a,.footer-grid-redesign p{color:#444}
.footer-brand-copy{max-width:340px;line-height:1.7;color:#4d4d4d!important}.footer-brand-meta{margin-top:16px!important;font-size:13px;color:#666!important}
.footer-trust{background:#f7f3ee;padding:28px 0 18px;border-top:1px solid #e0d8cf}.footer-trust__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.footer-trust__item h5{margin:0 0 12px;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:#595959;font-weight:800}
.footer-logo-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap;padding-top:12px;border-top:1px solid #d7d0c8;min-height:70px}
.footer-logo-row img{height:28px;width:auto;max-width:128px;object-fit:contain;filter:none;display:block}
.footer-logo-row--payments img{height:24px;max-width:112px}
.footer-logo-row--payments img:first-child{height:34px;max-width:138px}
.footer-logo-row--tech img{height:22px;max-width:104px}
.footer-logo-row--security img{height:28px;max-width:136px}
.footer-dev-text{font-weight:500;color:#2f2f2f;font-size:14px;line-height:1}
.footer-trust-copy{margin:10px 0 0!important;color:#666!important;font-size:13px;line-height:1.55}.footer-safe-link{display:inline-block;margin-top:8px;color:var(--red)!important;font-size:13px;font-weight:700}.footer-signature-redesign{padding:14px 20px 24px;text-align:center;color:#666;font-size:12px}
@media (max-width: 960px){.footer-newsletter__grid{grid-template-columns:1fr;min-height:auto}.footer-newsletter__beans{min-height:0}.footer-newsletter__beans img{position:relative;left:0;top:-22px;width:180px;margin:0 auto 4px}.footer-newsletter__content{text-align:center;max-width:none;padding-right:0}.newsletter-form{justify-content:center;flex-wrap:wrap}.footer-grid-redesign,.footer-trust__grid{grid-template-columns:1fr 1fr}}
@media (max-width: 680px){.footer-grid-redesign,.footer-trust__grid{grid-template-columns:1fr}.footer-newsletter{padding:26px 0 24px}.footer-newsletter__beans img{width:146px;top:-8px}.footer-newsletter__content h3{font-size:28px}.footer-newsletter__content p{font-size:16px}.newsletter-form{flex-direction:column;align-items:stretch}.newsletter-form input{width:100%}.newsletter-form .btn{width:100%}.footer-logo-row{gap:12px}.footer-logo-row img,.footer-logo-row--security img,.footer-logo-row--tech img{height:24px;max-width:110px}.footer-logo-row--payments img:first-child{height:30px;max-width:120px}}

/* v2.4.2 footer/email/kofi refinements */
.koffie-chat-root{right:18px!important;bottom:42px!important;z-index:110!important}
.koffie-chat-button{width:208px!important;min-width:208px!important;height:309px!important;min-height:309px!important;background:transparent!important}
.koffie-launcher-art{width:100%!important;height:100%!important;object-fit:contain!important;display:block!important}
.koffie-launcher-dismiss{top:16px!important;right:8px!important;width:28px!important;height:28px!important;font-size:16px!important}
@media (max-width:680px){.koffie-chat-root{right:8px!important;bottom:28px!important}.koffie-chat-button{width:150px!important;min-width:150px!important;height:222px!important;min-height:222px!important}}

.footer-newsletter{background:var(--red)!important;color:#fff!important}
.footer-newsletter__content h3,.footer-newsletter__content p,.newsletter-form input,.newsletter-form input::placeholder{color:#fff!important}
.footer-main{background:#e8e4de!important}
.footer-grid-redesign h4{color:#222!important}
.footer-grid-redesign a,.footer-grid-redesign p,.footer-brand-copy,.footer-brand-meta{color:#494949!important}
.footer-trust{background:#f3efea!important}
.footer-trust__item h5{color:#525252!important}
.footer-logo-row{border-top-color:#d7d0c8!important;gap:18px!important}
.footer-logo-row img{width:auto!important;object-fit:contain!important}
.footer-dev-text{font-weight:500!important;font-size:14px!important}
.footer-trust-copy{color:#666!important}
.footer-safe-link{font-size:13px!important}

.product-card__actions .btn{min-width:auto}

/* v2.4.8 / v2.4.9 refinements */
.featured-more-cta{margin-top:22px;border:1px solid var(--line);border-radius:26px;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;background:#f6f3ef}
.featured-more-cta p{margin:0;max-width:620px;color:#42506a;font-size:17px;line-height:1.35}
.featured-more-cta__button{padding:16px 22px;font-size:16px;font-weight:800;background:#fff}
.product-card__actions{justify-content:flex-start}
.product-card__actions .btn{padding:10px 16px;font-size:14px}
.product-card__actions form{flex:0 0 auto}

.footer-main{background:#efebe6!important;padding:34px 0 28px!important}
.footer-grid-redesign{grid-template-columns:1.1fr .8fr .95fr .95fr;gap:52px!important}
.footer-grid-redesign h4{font-size:13px;margin-bottom:12px!important;letter-spacing:.02em}
.footer-grid-redesign a,.footer-grid-redesign p{font-size:12px;line-height:1.5;margin-bottom:7px!important}
.footer-brand-copy{font-size:12px!important;line-height:1.6!important;max-width:280px!important}
.footer-brand-meta{font-size:11px!important}
.footer-contact-classic .footer-inline-link{gap:8px!important;font-size:12px!important;margin-bottom:8px!important}
.footer-contact-classic .footer-inline-link svg{width:16px!important;height:16px!important;min-width:16px!important}
.footer-contact-classic p{font-size:12px!important;line-height:1.5!important}
.footer-trust{padding:24px 0 14px!important}
.footer-trust__grid{gap:22px!important}
.footer-trust__item h5{font-size:11px!important;letter-spacing:.12em!important}
.footer-logo-row{gap:10px!important;min-height:54px!important;flex-wrap:nowrap!important;overflow:hidden}
.footer-logo-row img{height:20px!important;max-width:86px!important}
.footer-logo-row--payments img{height:18px!important;max-width:78px!important}
.footer-logo-row--payments img:first-child{height:24px!important;max-width:108px!important}
.footer-logo-row--tech img{height:19px!important;max-width:90px!important}
.footer-logo-row--security img{height:20px!important;max-width:100px!important}
.footer-dev-text{font-size:13px!important;white-space:nowrap}
.footer-trust-copy{font-size:11px!important;line-height:1.55!important}
.footer-safe-link{font-size:11px!important}
.footer-signature-redesign{font-size:11px!important;padding:12px 16px 18px!important}

.footer-newsletter{padding:26px 0 20px!important;overflow:hidden!important}
.footer-newsletter__grid{grid-template-columns:240px 1fr!important;gap:28px!important;min-height:112px!important}
.footer-newsletter__beans{min-height:132px!important}
.footer-newsletter__beans img{left:-10px!important;top:-56px!important;width:240px!important}
.footer-newsletter__content h3{font-size:30px!important;margin-bottom:6px!important}
.footer-newsletter__content p{font-size:16px!important;margin-bottom:14px!important}
.newsletter-form input{padding:12px 10px!important;font-size:15px!important}
.newsletter-form .btn{padding:10px 18px!important;min-width:116px!important}

.payment-trust-strip{padding:12px 14px!important}
.payment-logo-list--footer-match{flex-wrap:nowrap!important;gap:10px!important;overflow-x:auto;padding-bottom:2px}
.payment-logo-list--footer-match img{height:20px!important;max-width:88px!important;width:auto!important;object-fit:contain!important}
.payment-logo-list--footer-match img:first-child{height:24px!important;max-width:106px!important}

.koffie-chat-root{right:18px!important;bottom:24px!important;z-index:110!important}
.koffie-chat-button{width:270px!important;min-width:270px!important;height:398px!important;min-height:398px!important;background:transparent!important}
.koffie-launcher-art{width:100%!important;height:100%!important;object-fit:contain!important;display:block!important}
.koffie-launcher-dismiss{top:20px!important;right:6px!important;width:30px!important;height:30px!important;font-size:16px!important}
.koffie-chat-panel{width:min(340px,calc(100vw - 24px))!important;height:min(620px,calc(100dvh - 36px))!important;max-height:min(620px,calc(100dvh - 36px))!important;border-radius:24px!important}
.koffie-chat-header{padding:14px 14px 12px!important}
.koffie-chat-header h3{font-size:20px!important}
.koffie-chat-header p{font-size:11px!important}
.koffie-chat-body{padding:12px!important}
.koffie-bubble{font-size:13px!important;padding:11px 13px!important}
.koffie-card{flex-basis:220px!important;padding:14px!important}
.koffie-card h4{font-size:14px!important}.koffie-card p{font-size:12px!important}.koffie-card button{padding:10px 12px!important;font-size:12px!important}
.koffie-chat-footer{padding:8px 10px 10px!important}.koffie-compose{grid-template-columns:1fr 48px!important;gap:8px!important}.koffie-compose textarea,.koffie-field{min-height:44px!important;padding:11px 12px!important;font-size:13px!important}.koffie-send{height:44px!important;border-radius:14px!important;font-size:18px!important}
.koffie-registration-card{padding:18px!important;border-radius:22px!important}.koffie-registration-card h4{font-size:18px!important}.koffie-registration-card p{font-size:12px!important}

@media (max-width:980px){
  .featured-more-cta{padding:18px 20px}
  .featured-more-cta p{font-size:16px}
}
@media (max-width:760px){
  .featured-more-cta{flex-direction:column;align-items:flex-start}
  .featured-more-cta__button{width:100%;justify-content:center}
  .footer-newsletter__grid{grid-template-columns:1fr!important;gap:8px!important}
  .footer-newsletter__beans{min-height:88px!important}
  .footer-newsletter__beans img{left:0!important;top:-12px!important;width:160px!important;margin:0 auto!important;position:relative!important}
  .footer-newsletter__content{text-align:center!important}
  .footer-grid-redesign{gap:24px!important}
}
@media (max-width:680px){
  .koffie-chat-root{right:8px!important;bottom:16px!important}
  .koffie-chat-button{width:184px!important;min-width:184px!important;height:270px!important;min-height:270px!important}
  .koffie-chat-panel{width:min(100vw - 14px, 320px)!important;height:min(66dvh, calc(100dvh - 30px))!important;max-height:min(66dvh, calc(100dvh - 30px))!important}
  .payment-logo-list--footer-match img{height:18px!important;max-width:80px!important}
  .footer-logo-row{flex-wrap:wrap!important}
}

/* v2.0 integrated updates */
.social-btn-cart{position:relative;padding-right:46px!important}.cart-badge{position:absolute;right:10px;top:50%;transform:translateY(-50%);min-width:22px;height:22px;border-radius:999px;background:#D4282F;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;padding:0 6px}.featured-more-cta__button,.testimonial-cta .btn.btn-primary{background:#fff!important;color:#D4282F!important;border:1px solid #D4282F!important;box-shadow:none!important}.featured-more-cta__button:hover,.testimonial-cta .btn.btn-primary:hover{background:#D4282F!important;color:#fff!important}.footer-inline-link{display:flex;align-items:center;gap:10px}.footer-inline-link svg{width:17px;height:17px;flex:0 0 auto}.footer-inline-link.is-whatsapp{color:#25D366!important}.footer-inline-link.is-instagram{color:#E4405F!important}.footer-inline-link.is-mail{color:#4f46e5!important}.footer-inline-link.is-location{color:#8a5a36!important;margin:0}.cookie-banner{background:#f6f1ea!important;color:#241f1a!important;border:1px solid #ded5ca!important}.cookie-banner__inner{grid-template-columns:auto 1fr auto!important;gap:16px!important}.cookie-banner__media img{width:84px;height:84px;object-fit:contain;display:block}.cookie-banner__text strong{font-size:18px;color:#201912!important}.cookie-banner__text p{color:#5d5349!important}.btn-cookie-solid{background:#D4282F!important;border-color:#D4282F!important;color:#fff!important}.btn-cookie-solid:hover{filter:brightness(.96)}@media (max-width:860px){.cookie-banner__inner{grid-template-columns:1fr!important}.cookie-banner__media{display:flex;justify-content:center}.cookie-banner__actions{justify-content:flex-start!important}}.koffie-chat-root{right:18px!important;bottom:20px!important}.koffie-chat-button{width:270px!important;min-width:270px!important;height:402px!important;min-height:402px!important}.koffie-launcher-dismiss{top:22px!important}.footer-newsletter__beans img{width:240px!important;top:-76px!important}.footer-grid-redesign a,.footer-grid-redesign p{font-size:11px!important;line-height:1.45!important}.footer-grid-redesign{gap:62px!important}.footer-trust__item h5{font-size:12px!important}.footer-trust-copy,.footer-signature-redesign{font-size:12px!important}.cart-actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}.grind-field{margin:10px 0 0}.grind-field label{display:block;font-size:12px;font-weight:700;margin-bottom:5px;color:#5a5149}.grind-field select{width:100%;border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:#fff}.admin-shortcut-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.admin-shortcut-card{background:#fff;border:1px solid #e7dfd5;border-radius:22px;padding:18px;box-shadow:var(--shadow)}.admin-shortcut-card h3{margin:0 0 8px}.admin-shortcut-card p{margin:0 0 14px;color:#666}.promo-badge{display:inline-flex;align-items:center;gap:6px;background:#f8f3ef;border:1px solid #eadfd3;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700;color:#7a4b2a}.unified-note{padding:16px 18px;border:1px solid #eadfd3;background:#fcf8f4;border-radius:18px;margin-bottom:18px}@media (max-width:680px){.koffie-chat-root{right:6px!important;bottom:18px!important}.koffie-chat-button{width:176px!important;min-width:176px!important;height:262px!important;min-height:262px!important}}

.admin-user-badge{display:grid;gap:2px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);border-radius:16px;padding:12px 14px;margin:0 0 12px}.admin-user-badge strong{font-size:14px}.admin-user-badge span{font-size:12px;color:rgba(255,255,255,.72)}

.admin-sidebar{overflow:hidden}.admin-sidebar-inner{display:flex;flex-direction:column;height:100%}.admin-user-badge{display:grid;gap:4px;padding:12px 14px;margin:0 0 12px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(255,255,255,.04)}.admin-user-badge span{font-size:12px;color:rgba(255,255,255,.72)}.admin-sidebar-nav{display:flex;flex-direction:column;gap:4px;overflow:auto;padding-right:4px;min-height:0}.admin-sidebar-nav::-webkit-scrollbar{width:8px}.admin-sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}.operations-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}.mini-table{width:100%;border-collapse:collapse}.mini-table td,.mini-table th{padding:10px 0;border-bottom:1px solid #eee;text-align:left;vertical-align:top}.pill{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;border:1px solid #eadfd3;background:#fffaf6;font-size:12px;font-weight:700;color:#7a4b2a}.soft-box{padding:16px;border:1px solid #eadfd3;background:#fffaf8;border-radius:18px}.code-box{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.55;background:#111;color:#fff;padding:14px;border-radius:16px;overflow:auto}.btn-sm{padding:10px 14px;font-size:13px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width:980px){.admin-sidebar-inner{height:auto}.admin-sidebar-nav{overflow:visible}.operations-grid,.two-col{grid-template-columns:1fr}}
.admin-sidebar-logo{display:block;width:100%;max-width:180px;height:auto;object-fit:contain;margin:0 0 16px}

.integration-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.integration-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow)}.integration-card--wide{grid-column:1/-1}.integration-card__head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.integration-card__head h3{margin:0;font-size:20px;letter-spacing:-.02em}.integration-subgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}@media (max-width:1100px){.integration-grid{grid-template-columns:1fr}.integration-card--wide{grid-column:auto}.integration-subgrid{grid-template-columns:1fr}}
/* v3.1 cleanup and visual fixes */
.admin-return-link{margin-top:8px;border:1px solid rgba(255,255,255,.12)}
.admin-table-thumb{width:52px;height:52px;object-fit:cover;border-radius:12px;border:1px solid #ece4db;background:#fff}
.product-gallery-admin{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;margin-top:14px}
.product-gallery-admin__item{display:grid;gap:8px;padding:10px;border:1px solid #ece4db;border-radius:16px;background:#faf8f5}
.product-gallery-admin__item img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px}
.admin-sidebar-logo{max-width:150px!important;width:auto!important;height:auto!important;aspect-ratio:auto!important}
.footer-newsletter{overflow:visible!important}.footer-newsletter__grid{overflow:visible!important;align-items:end!important}.footer-newsletter__beans{min-height:170px!important}.footer-newsletter__beans img{width:270px!important;top:-112px!important;left:-8px!important;object-fit:contain!important}.footer-newsletter__content{padding-top:10px}
.footer-inline-link{color:#444!important}.footer-inline-link span{color:#444!important}.footer-inline-link.is-whatsapp svg{color:#25D366!important}.footer-inline-link.is-instagram svg{color:#E4405F!important}.footer-inline-link.is-mail svg{color:#4f46e5!important}.footer-inline-link.is-location svg{color:#8a5a36!important}
.institution-kofi{grid-template-columns:1.25fr .75fr!important;align-items:center!important}.kofi-showcase{background:none!important;border:none!important;box-shadow:none!important;padding:0!important;display:flex;justify-content:center;align-items:flex-end}.kofi-showcase img{max-width:320px!important;width:100%!important;margin:0 auto!important}.kofi-page-chat .kofi-showcase img{max-width:300px!important}
.modal{z-index:1200!important}.modal-box.freight-modal-box,.freight-modal-box{max-width:860px!important;grid-template-columns:1fr!important}.modal-content-full{padding:40px 36px!important}.modal-is-open{overflow:hidden}.modal-is-open .cookie-banner,.modal-is-open .koffie-chat-root{display:none!important}
.koffie-chat-root{right:18px!important;bottom:20px!important}.koffie-chat-button{width:405px!important;min-width:405px!important;height:603px!important;min-height:603px!important}.koffie-launcher-dismiss{top:22px!important}
@media (max-width:980px){.institution-kofi{grid-template-columns:1fr!important}.kofi-showcase{order:-1}.footer-newsletter__beans img{position:relative!important;top:-20px!important;left:0!important;margin:0 auto!important;width:210px!important}}
@media (max-width:680px){.koffie-chat-root{right:6px!important;bottom:18px!important}.koffie-chat-button{width:264px!important;min-width:264px!important;height:393px!important;min-height:393px!important}.footer-newsletter__beans{min-height:100px!important}.footer-newsletter__beans img{width:170px!important;top:-10px!important}}


/* v3.3 fixes */
.integration-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-start;margin-top:16px}
.footer-contact-classic .footer-inline-link,.footer-contact-classic .footer-inline-link span,.footer-contact-classic .footer-inline-link svg{color:#444!important;stroke:currentColor!important}
.footer-newsletter{padding:0;background:#d4282f;overflow:visible}
.footer-newsletter__grid{display:grid;grid-template-columns:170px 1fr;gap:22px;align-items:center;padding:26px 0}
.footer-newsletter__beans{align-self:end;margin-top:-26px}
.footer-newsletter__beans img{width:150px;max-width:none;display:block}
.koffie-chat-button{width:220px!important;min-width:220px!important;height:94px!important;min-height:94px!important;background-size:contain!important}
.koffie-chat-root{bottom:96px!important;right:16px!important}
@media (max-width:640px){.footer-newsletter__grid{grid-template-columns:120px 1fr;padding:22px 0}.footer-newsletter__beans{margin-top:-16px}.footer-newsletter__beans img{width:120px}.koffie-chat-button{width:176px!important;min-width:176px!important;height:76px!important;min-height:76px!important}}
.kofi-showcase{background:transparent;border:none;box-shadow:none;padding:0}
.kofi-showcase img{max-width:230px}


.social-btn-icon-only{padding:0 14px;min-width:52px;justify-content:center}
.social-btn-icon-only span{display:none}
.footer-newsletter{padding:22px 0 16px!important;overflow:hidden!important}
.footer-newsletter__grid{grid-template-columns:240px 1fr!important;gap:26px!important;min-height:96px!important}
.footer-newsletter__beans{min-height:118px!important}
.footer-newsletter__beans img{left:-6px!important;top:-18px!important;width:226px!important}
@media (max-width: 960px){
  .footer-newsletter{padding:20px 0 16px!important}
  .footer-newsletter__beans{min-height:92px!important}
  .footer-newsletter__beans img{top:-2px!important;width:170px!important}
}


/* v3.6.7 mobile ux + newsletter revert */
.socials-store .social-btn:first-child{gap:10px !important;}
.socials-store .social-btn:first-child span{display:inline !important;}

.footer-newsletter{padding:26px 0 20px !important;background:#d4282f !important;overflow:visible !important;}
.footer-newsletter__grid{display:grid !important;grid-template-columns:240px 1fr !important;gap:28px !important;align-items:center !important;min-height:112px !important;padding:0 !important;}
.footer-newsletter__beans{min-height:132px !important;align-self:end !important;margin-top:0 !important;}
.footer-newsletter__beans img{position:absolute !important;left:-10px !important;top:-42px !important;width:240px !important;max-width:none !important;height:auto !important;display:block !important;}
.footer-newsletter__content{text-align:left !important;max-width:720px !important;padding-right:12px !important;padding-top:10px !important;}
.footer-newsletter__content h3{font-size:30px !important;margin-bottom:6px !important;}
.footer-newsletter__content p{font-size:16px !important;margin-bottom:14px !important;}
.newsletter-form input{padding:12px 10px !important;font-size:15px !important;}
.newsletter-form .btn{padding:10px 18px !important;min-width:116px !important;}

html,body{overflow-x:hidden;}
body *{min-width:0;}
.container{width:min(1180px, calc(100% - 32px)) !important;}
.nav-wrap{gap:14px !important;}
.nav,.socials-store{min-width:0;}

@media (max-width: 980px){
  .nav{display:none;position:absolute;top:82px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:18px 16px;flex-direction:column;z-index:70;}
  .nav.open{display:flex;}
  .menu-toggle{display:block;}
  .socials-store{display:none !important;}
  .footer-newsletter__grid{grid-template-columns:1fr !important;gap:8px !important;min-height:auto !important;}
  .footer-newsletter__beans{min-height:88px !important;display:flex !important;justify-content:center !important;}
  .footer-newsletter__beans img{position:relative !important;left:0 !important;top:-6px !important;width:160px !important;margin:0 auto !important;}
  .footer-newsletter__content{text-align:center !important;max-width:none !important;padding-right:0 !important;}
  .newsletter-form{justify-content:center !important;flex-wrap:wrap !important;}
  .footer-grid-redesign,.footer-trust__grid{grid-template-columns:1fr 1fr !important;gap:24px !important;}
}
@media (max-width: 768px){
  .container{width:calc(100% - 24px) !important;}
  .page-hero,.section,.hero{padding-left:0 !important;padding-right:0 !important;}
  .footer-main{padding:28px 0 22px !important;}
  .footer-grid-redesign,.footer-trust__grid{grid-template-columns:1fr !important;gap:20px !important;}
  .footer-brand-copy,.footer-grid-redesign a,.footer-grid-redesign p{max-width:100% !important;word-break:break-word;}
  .footer-logo-row{flex-wrap:wrap !important;overflow:visible !important;min-height:auto !important;}
  .footer-logo-row img{max-width:110px !important;height:auto !important;}
  .footer-newsletter{padding:22px 0 18px !important;}
  .footer-newsletter__beans img{width:140px !important;top:-4px !important;}
  .footer-newsletter__content h3{font-size:24px !important;}
  .footer-newsletter__content p{font-size:15px !important;}
  .newsletter-form{flex-direction:column !important;align-items:stretch !important;}
  .newsletter-form input,.newsletter-form .btn{width:100% !important;}
  .social-btn{padding:10px 14px !important;}
}
@media (max-width: 520px){
  .brand img{height:50px !important;}
  .menu-toggle{font-size:30px !important;}
  .footer-contact-classic .footer-inline-link{align-items:flex-start !important;}
  .footer-contact-classic .footer-inline-link span,.footer-brand-copy,.footer-grid-redesign a,.footer-grid-redesign p{font-size:14px !important;line-height:1.55 !important;}
}


/* v3.7.2 footer newsletter + security + kofi launcher tweaks */
.footer-logo-row--security img{height:24px!important;max-width:110px!important;object-fit:contain!important;display:block}
.footer-logo-row--security img:last-child{height:24px!important;max-width:96px!important}

.footer-newsletter{overflow:visible!important}
.footer-newsletter__grid{align-items:end!important;padding-bottom:0!important}
.footer-newsletter__beans{align-self:end!important;display:flex!important;align-items:flex-end!important;min-height:132px!important;margin-top:0!important}
.footer-newsletter__beans img{position:relative!important;left:0!important;top:0!important;bottom:0!important;margin:0 auto 0 0!important;display:block!important;transform:none!important}

.koffie-chat-root .koffie-launcher-wrap{position:relative!important}
.koffie-chat-root .koffie-chat-button{overflow:visible!important}
.koffie-chat-root .koffie-launcher-dismiss{top:6px!important;right:10px!important}

@media (max-width:980px){
  .footer-newsletter__grid{padding-bottom:0!important}
  .footer-newsletter__beans{min-height:110px!important}
}
@media (max-width:680px){
  .footer-newsletter__grid{padding-bottom:0!important}
  .footer-newsletter__beans{min-height:92px!important}
  .footer-newsletter__beans img{margin:0 auto!important}
  .footer-logo-row--security img{height:22px!important;max-width:96px!important}
  .footer-logo-row--security img:last-child{max-width:88px!important}
  .koffie-chat-root .koffie-launcher-dismiss{top:4px!important;right:8px!important}
}

.btn-share{border-color:#d8ccc0!important;background:#fff7f1!important;color:#8a4a20!important}
.btn-share:hover{background:#D4282F!important;color:#fff!important;border-color:#D4282F!important}
.product-card__actions{display:flex;flex-direction:column;gap:10px}
.product-card__actions form{display:block}
.modal-box-share{max-width:720px!important;grid-template-columns:1fr!important}
.modal-content-share{padding:32px!important}
.share-actions-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}
.share-link-preview{margin-top:14px}
.share-link-preview input{font-size:14px}
@media (max-width:680px){.share-actions-grid{grid-template-columns:1fr}}


.product-card{gap:0}
.product-card__body{display:grid;gap:10px;margin-bottom:10px}
.product-card__head{display:grid;gap:8px}
.product-card__head h3{margin:0;font-size:30px;line-height:1.05;letter-spacing:-.03em}
.product-card__price{align-items:center;padding-top:2px}
.product-card__price strong{font-size:22px;color:#272019}
.product-card p{display:block;overflow:visible;min-height:auto;margin:0;color:#6c6258}
.product-card__actions{display:grid;grid-template-columns:1fr;gap:12px;align-items:stretch}
.product-buy-form{display:grid;gap:10px}
.variation-field{background:#fbf8f4;border:1px solid #ece2d6;border-radius:18px;padding:10px 12px}
.variation-field label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#8a7767;margin-bottom:6px}
.variation-field select{border:1px solid #d9cec2;border-radius:999px;padding:9px 14px;background:#fff;color:#2a221c;font-weight:600;min-height:42px}
.btn-share-icon{display:inline-flex;align-items:center;gap:10px}
.share-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex:0 0 18px}
.share-icon svg{width:18px;height:18px}
.modal-box{align-items:stretch}
.modal-content{display:flex;flex-direction:column;gap:16px}
.modal-content h2{margin:0;font-size:42px;line-height:1.02;letter-spacing:-.04em}
.modal-content .meta{align-items:center;margin-top:-2px}
.modal-content .meta strong{font-size:24px;color:#272019}
.modal-content .muted{line-height:1.65}
.modal-actions{display:grid;grid-template-columns:1fr;gap:14px;align-items:stretch}
.modal-actions form{display:grid;gap:10px}
.modal-actions .btn{width:100%}
.product-detail-shell{display:grid;grid-template-columns:minmax(320px,1fr) minmax(320px,1fr);gap:28px;background:#fff;border:1px solid var(--line);border-radius:30px;padding:22px;box-shadow:var(--shadow)}
.product-detail-gallery{aspect-ratio:1/1;border-radius:24px;background:#f7f7f7;overflow:hidden}
.product-detail-gallery img{width:100%;height:100%;object-fit:contain}
.product-detail-info{display:flex;flex-direction:column;gap:18px;padding:8px 4px}
.product-detail-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.product-detail-head h2{margin:0;font-size:42px;line-height:1.02;letter-spacing:-.04em}
.product-detail-price{display:grid;gap:6px;text-align:right}
.product-detail-price span{font-size:14px;color:#8a7767}
.product-detail-price strong{font-size:26px;color:#272019}
.product-detail-description{font-size:16px;line-height:1.72;color:#5d5349}
.product-detail-actions{margin-top:auto}
.product-detail-cta-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.share-link-preview .input{font-size:13px}
.share-actions-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media (max-width:980px){
  .product-detail-shell{grid-template-columns:1fr;padding:18px}
  .product-detail-head{display:grid}
  .product-detail-price{text-align:left}
}
@media (max-width:640px){
  .product-card__head h3{font-size:22px}
  .modal-content h2,.product-detail-head h2{font-size:32px}
  .product-detail-cta-row,.share-actions-grid{grid-template-columns:1fr}
}


/* v3.7.6 hotfix admin/sidebar + account modal + product card refinements */
html.admin-html,body.admin-body{overflow-x:hidden}
.admin-shell{display:block;min-height:100vh}
.admin-sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;overflow:auto;z-index:120;padding:24px}
.admin-main{margin-left:260px;min-width:0;min-height:100vh;width:calc(100% - 260px);padding:28px}
.admin-sidebar-inner{min-height:100%;display:flex;flex-direction:column}
.admin-sidebar-nav{display:flex;flex-direction:column;gap:4px}

.product-card{display:flex;flex-direction:column;gap:12px}
.product-card .meta{margin-top:auto}
.product-card__actions{display:grid;grid-template-columns:1fr;gap:12px;align-items:stretch}
.product-card__actions > .btn,
.product-card__actions > form,
.product-card__actions > button{width:100%;margin:0}
.product-card__actions form{display:flex;flex-direction:column;gap:12px}
.product-card__actions form > .btn,
.product-card__actions > .btn{width:100%;min-height:48px;justify-content:center}
.product-card__actions .btn{border-radius:999px;font-weight:800}
.product-card__actions .btn-primary,
.product-card__actions .btn-share{min-height:48px}
.product-card__actions .btn-share{display:inline-flex;align-items:center;justify-content:center;gap:10px}
.product-card__actions .share-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}
.product-card__actions .share-icon svg{width:18px;height:18px}

.variation-field,.grind-field{display:flex;flex-direction:column;gap:6px;margin:0}
.variation-field label,.grind-field label{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#7d6758;padding-left:4px}
.variation-field select,.grind-field select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  min-height:46px;padding:12px 42px 12px 16px;border-radius:999px;
  border:1px solid #d9c9bc;background:
    linear-gradient(180deg,#fff 0%,#f8f3ee 100%);
  color:#3e2d22;font-weight:700;line-height:1.2;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath d='M1 1.5L7 7.5L13 1.5' fill='none' stroke='%23835a3c' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;background-size:14px 9px;
  box-shadow:0 8px 20px rgba(42,25,14,.04)
}
.variation-field select:focus,.grind-field select:focus{outline:none;border-color:#c29c84;box-shadow:0 0 0 3px rgba(212,40,47,.08)}

.hero-actions.modal-actions,.product-detail-actions{align-items:flex-end;gap:14px;flex-wrap:wrap}
.hero-actions.modal-actions form,.product-detail-actions form{display:flex;flex-direction:column;gap:12px;min-width:min(100%,280px)}
.hero-actions.modal-actions .btn,.product-detail-actions .btn{min-height:48px}
.modal-box{position:relative;max-height:min(90vh,980px)}
.modal-content{display:flex;flex-direction:column;gap:14px}
.modal-content .meta{align-items:center}
.modal-content .muted{margin:0}
.btn-share-icon{gap:10px}
.btn-share-icon .share-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}
.btn-share-icon .share-icon svg{width:18px;height:18px}

.account-order-modal{padding:20px}
.account-order-modal .modal-box{width:min(980px,100%);max-height:calc(100vh - 40px);overflow:auto;display:block;position:relative;border-radius:28px}
.account-order-modal .modal-content-full{padding:24px}
.account-order-modal .close-modal{position:sticky;top:14px;right:14px;margin-left:auto;display:flex;align-items:center;justify-content:center;z-index:5;box-shadow:0 8px 20px rgba(0,0,0,.12)}

@media (max-width:980px){
  .admin-shell{display:grid;grid-template-columns:1fr}
  .admin-sidebar{position:relative;width:auto;height:auto;overflow:visible}
  .admin-main{margin-left:0;width:100%;padding:20px}
}
@media (max-width:760px){
  .account-order-modal{padding:10px}
  .account-order-modal .modal-box{max-height:calc(100vh - 20px);border-radius:22px}
  .account-order-modal .modal-content-full{padding:18px}
  .product-card__actions{gap:10px}
  .product-card__actions form{gap:10px}
  .hero-actions.modal-actions form,.product-detail-actions form{min-width:100%}
}


.shipping-toolbar{display:grid;grid-template-columns:minmax(260px,1.3fr) minmax(180px,.7fr) minmax(180px,.7fr) auto;gap:14px;align-items:end}.shipping-toolbar-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end}.shipping-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-disabled{opacity:.55;pointer-events:none}.shipping-pill{white-space:nowrap}.shipping-pill.status-requested,.shipping-pill.status-pending{background:#fff8ef;border-color:#f0dcc0;color:#9a5a17}.shipping-pill.status-label_generated{background:#f5f6ff;border-color:#d8dcff;color:#3843a5}.shipping-pill.status-posted{background:#eef8ff;border-color:#c9e3ff;color:#1c5f9c}.shipping-pill.status-delivered{background:#eefaf0;border-color:#cae9d0;color:#21683a}.shipping-pill.status-cancelled{background:#fff1f1;border-color:#f0cccc;color:#a13535}.shipping-webhooks{display:grid;gap:12px}.shipping-modal-shell{position:relative;background:#f6f6f6;border-radius:28px;width:min(1180px,calc(100vw - 36px));max-height:min(92vh,980px);overflow:hidden;display:flex;flex-direction:column}.shipping-modal-header{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:26px 28px 0 28px}.shipping-modal-header-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.shipping-modal-content{padding:20px 28px 28px;overflow:auto}.shipping-modal-grid{align-items:start}.shipping-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.shipping-form-span{grid-column:1 / -1}.shipping-form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.shipping-item-row{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-top:1px solid #ece4db}.shipping-item-row:first-of-type{margin-top:10px}.shipping-timeline{display:grid;gap:12px}.mini-table-wrap{overflow:auto}.shipping-modal-shell .close-modal{z-index:2}.shipping-modal-shell .panel{box-shadow:none}.shipping-hero-note{margin-top:10px}@media (max-width:980px){.shipping-toolbar{grid-template-columns:1fr 1fr}.shipping-toolbar-actions{grid-column:1 / -1;justify-content:flex-start}.shipping-form-grid,.shipping-modal-grid{grid-template-columns:1fr}.shipping-modal-shell{width:min(100vw - 18px, 980px);max-height:94vh}.shipping-modal-content{padding:16px 16px 20px}.shipping-modal-header{padding:20px 16px 0 16px;align-items:flex-start;flex-direction:column}}@media (max-width:640px){.shipping-toolbar{grid-template-columns:1fr}.shipping-actions{flex-direction:column;align-items:flex-start}.shipping-modal-header-actions{width:100%}.shipping-modal-header-actions .btn{width:100%}}


/* v4.5 newsletter + checkout/payment fixes */
.footer-newsletter{padding:0 0 0!important;background:#d4282f!important;overflow:visible!important}
.footer-newsletter__grid{grid-template-columns:260px 1fr!important;gap:32px!important;align-items:end!important;min-height:0!important;padding:0!important}
.footer-newsletter__beans{min-height:0!important;align-self:end!important;display:flex!important;align-items:flex-end!important;justify-content:flex-start!important;margin:0!important}
.footer-newsletter__beans img{position:relative!important;left:0!important;top:-42px!important;bottom:auto!important;width:250px!important;max-width:none!important;margin:0!important}
.footer-newsletter__content{padding:26px 0 24px!important}
.footer-newsletter__content h3{margin:0 0 6px!important;font-size:32px!important}
.footer-newsletter__content p{margin:0 0 18px!important}
@media (max-width: 900px){
  .footer-newsletter__grid{grid-template-columns:180px 1fr!important;gap:18px!important}
  .footer-newsletter__beans img{width:178px!important;top:-20px!important}
}
@media (max-width: 640px){
  .footer-newsletter__grid{grid-template-columns:1fr!important;gap:8px!important}
  .footer-newsletter__beans{justify-content:center!important}
  .footer-newsletter__beans img{width:156px!important;top:-8px!important}
  .footer-newsletter__content{padding:4px 0 18px!important;text-align:center!important}
}

/* mobile header/footer hotfix from stable 4.1 base */
@media (max-width:980px){
  .nav-wrap{display:grid!important;grid-template-columns:auto 1fr auto auto!important;align-items:center!important;gap:10px!important;min-height:78px!important}
  .brand{grid-column:1!important}
  .socials-store{display:flex!important;grid-column:3!important;justify-self:end!important;align-items:center!important;gap:8px!important}
  .socials-store .social-btn{width:42px!important;height:42px!important;min-width:42px!important;padding:0!important;border-radius:999px!important;justify-content:center!important;gap:0!important;overflow:visible!important}
  .socials-store .social-btn span{display:none!important}
  .socials-store .social-btn svg{width:18px!important;height:18px!important}
  .socials-store .social-btn-cart{position:relative!important}
  .socials-store .social-btn-cart .cart-badge{right:-3px!important;top:-4px!important;transform:none!important;min-width:18px!important;height:18px!important;font-size:10px!important;padding:0 4px!important}
  .menu-toggle{display:flex!important;grid-column:4!important;justify-self:end!important;align-items:center!important;justify-content:center!important;width:42px!important;height:42px!important;border:1px solid var(--line)!important;border-radius:999px!important;background:#fff!important;color:#1f1f1f!important;font-size:24px!important;line-height:1!important;padding:0!important}
  .nav{top:88px!important;left:12px!important;right:12px!important;border:1px solid var(--line)!important;border-radius:20px!important;box-shadow:0 18px 40px rgba(0,0,0,.08)!important;padding:18px 18px 20px!important;z-index:80!important}
}

@media (max-width:680px){
  .footer-main{padding:24px 0 18px!important}
  .footer-grid-redesign{grid-template-columns:1fr!important;gap:18px!important}
  .footer-grid-redesign a,.footer-grid-redesign p{font-size:14px!important;line-height:1.55!important}
  .footer-contact-classic .footer-inline-link{display:flex!important;align-items:flex-start!important;gap:10px!important;margin:0 0 10px!important}
  .footer-contact-classic .footer-inline-link svg{width:18px!important;height:18px!important;flex:0 0 18px!important;margin-top:2px!important}

  .footer-trust{padding:22px 0 18px!important}
  .footer-trust__grid{grid-template-columns:1fr!important;gap:18px!important}
  .footer-trust__item h5{font-size:13px!important;letter-spacing:.1em!important;margin:0 0 10px!important}
  .footer-logo-row{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;align-items:center!important;justify-items:start!important;gap:14px 12px!important;min-height:0!important;flex-wrap:unset!important;overflow:visible!important;padding-top:12px!important}
  .footer-logo-row--payments{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .footer-logo-row img,.footer-logo-row--payments img,.footer-logo-row--tech img,.footer-logo-row--security img{height:22px!important;max-width:100%!important;width:auto!important;object-fit:contain!important}
  .footer-logo-row--payments img:first-child{height:24px!important;max-width:108px!important}
  .footer-dev-text{grid-column:1 / -1!important;display:block!important;font-size:14px!important;line-height:1.35!important;white-space:normal!important}
  .footer-trust-copy{font-size:14px!important;line-height:1.55!important;margin-top:10px!important}
  .footer-safe-link{font-size:14px!important;line-height:1.45!important;margin-top:10px!important}
  .footer-signature-redesign{padding:12px 16px 24px!important;font-size:12px!important;line-height:1.5!important}
}

@media (max-width:430px){
  .nav-wrap{grid-template-columns:auto 1fr auto auto!important;gap:8px!important;min-height:74px!important}
  .brand img{height:46px!important}
  .socials-store{gap:6px!important}
  .socials-store .social-btn,.menu-toggle{width:38px!important;height:38px!important;min-width:38px!important}
  .socials-store .social-btn svg{width:17px!important;height:17px!important}
}

@media (max-width:980px){
  .socials-store .social-btn-instagram{width:42px!important;height:42px!important;min-width:42px!important;padding:0!important;justify-content:center!important;gap:0!important;overflow:hidden!important}
  .socials-store .social-btn-instagram .social-btn-label{display:none!important}
}

@media (max-width:430px){
  .socials-store .social-btn-instagram{width:38px!important;height:38px!important;min-width:38px!important}
}


/* 2026-04-02 mobile header + iOS button visibility + secure session refresh */
@media (max-width:980px){
  .site-header .socials-store .social-btn-instagram{padding:0!important;justify-content:center!important;gap:0!important;overflow:hidden!important}
  .site-header .socials-store .social-btn-instagram .social-btn-label,
  .site-header .socials-store .social-btn-instagram span{display:none!important;width:0!important;max-width:0!important;font-size:0!important;line-height:0!important;opacity:0!important;visibility:hidden!important;overflow:hidden!important}
}

button.btn,
input[type="submit"].btn,
.cart-item-actions .btn,
.coupon-form .btn,
.checkout-coupon-box .btn,
.cart-summary .btn,
.summary-actions .btn{
  color:#1f1f1f!important;
  -webkit-text-fill-color:#1f1f1f!important;
  opacity:1!important;
}

button.btn.btn-primary,
input[type="submit"].btn.btn-primary,
.btn-primary{
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
}


/* 2026-04-02 newsletter button contrast fix */
.footer-newsletter .newsletter-form .btn.btn-footer{color:#fff!important;-webkit-text-fill-color:#fff!important;border-color:rgba(255,255,255,.65)!important;background:transparent!important}
.footer-newsletter .newsletter-form .btn.btn-footer:hover{background:#fff!important;color:#D4282F!important;-webkit-text-fill-color:#D4282F!important}


/* 2026-04-02 newsletter audience sync + google review CTA color fix */
.testimonial-cta .btn.btn-primary{
  background:var(--red)!important;
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  border-color:var(--red)!important;
}
.testimonial-cta .btn.btn-primary:hover{
  background:#bb1f26!important;
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  border-color:#bb1f26!important;
}


body.payment-processing-open{overflow:hidden}
.payment-processing-modal{position:fixed;inset:0;z-index:160;display:grid;place-items:center;padding:20px}
.payment-processing-modal[hidden]{display:none!important}
.payment-processing-modal__backdrop{position:absolute;inset:0;background:rgba(17,17,17,.42);backdrop-filter:blur(4px)}
.payment-processing-modal__dialog{position:relative;z-index:1;width:min(100%,420px);background:#fff;border:1px solid rgba(212,40,47,.14);border-radius:28px;box-shadow:0 28px 80px rgba(17,17,17,.18);padding:28px 24px;text-align:center}
.payment-processing-modal__brand{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 14px;border-radius:999px;background:#f8f1f1;color:#9d2328;font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.payment-processing-modal__spinner{width:58px;height:58px;border-radius:50%;border:4px solid #f1d4d6;border-top-color:#d4282f;margin:0 auto 18px;animation:koffieSpin .9s linear infinite}
.payment-processing-modal__title{margin:0 0 10px;font-size:28px;line-height:1.08}
.payment-processing-modal__text{margin:0;color:#4b5563;font-size:15px;line-height:1.6}
.payment-processing-modal__note{margin-top:16px;padding-top:16px;border-top:1px solid #ededed;color:#6b7280;font-size:13px;line-height:1.5}
@keyframes koffieSpin{to{transform:rotate(360deg)}}
@media (max-width:640px){.payment-processing-modal__dialog{padding:24px 18px;border-radius:24px}.payment-processing-modal__title{font-size:24px}}


.koffie-editor{border:1px solid #ddd;border-radius:16px;background:#fff;overflow:hidden}.koffie-editor__toolbar{display:flex;gap:8px;flex-wrap:wrap;padding:10px;border-bottom:1px solid #eee;background:#faf8f5}.koffie-editor__btn,.koffie-editor__select{border:1px solid #ddd;background:#fff;border-radius:10px;padding:8px 10px;font:inherit}.koffie-editor__surface{min-height:180px;padding:14px;outline:none;line-height:1.6}.koffie-editor__surface p{margin:0 0 12px}.koffie-editor__surface img{max-width:100%;height:auto;border-radius:12px;display:block;margin:14px 0}.koffie-editor__surface h2,.koffie-editor__surface h3{margin:0 0 12px}.koffie-editor__surface ul,.koffie-editor__surface ol{padding-left:24px}.koffie-editor__surface blockquote{margin:0 0 12px;padding-left:14px;border-left:3px solid #d4282f;color:#555}


/* v5 home carousels */
.hero-carousel-section{padding-bottom:20px}
.multi-card-carousel{position:relative}
.multi-card-carousel .carousel-viewport{overflow:hidden;padding:18px 6px 24px;margin:-18px -6px -24px}
.multi-card-carousel .carousel-track{display:flex;transition:transform .55s ease}
.multi-card-carousel .carousel-page{min-width:100%}
.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:16px}
.carousel-dots button{width:8px;height:8px;border:none;border-radius:999px;background:#d0d0d0;padding:0;cursor:pointer}
.carousel-dots button.active{background:#D4282F}
.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.96);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;z-index:2;cursor:pointer}
.carousel-arrow.prev{left:-18px}
.carousel-arrow.next{right:-18px}
.hero-main-carousel .carousel-arrow{top:42%}
.hero-main-carousel .carousel-page{padding:0 2px}
.hero-slide .hero-grid{min-height:420px}
.card-grid-featured{grid-template-columns:repeat(4,minmax(0,1fr))}
.testimonial-grid-carousel{grid-template-columns:repeat(4,minmax(0,1fr))}
.instagram-grid-carousel{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start}
.instagram-home-carousel .instagram-card{height:auto;min-height:0}
.instagram-home-carousel .instagram-card__media{aspect-ratio:1/1}
.instagram-home-carousel .instagram-card__body{padding:14px 16px 16px;gap:8px}
.instagram-home-carousel .instagram-card__body h3{font-size:16px;line-height:1.25}
.instagram-home-carousel .instagram-card__body .rich-inline{font-size:13px;line-height:1.45;color:var(--muted);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.instagram-home-carousel .instagram-card__cta{font-size:13px;margin-top:2px}
.testimonials-carousel,.instagram-home-carousel{padding:0 8px}
.testimonials-carousel .carousel-arrow,.instagram-home-carousel .carousel-arrow{top:45%}
@media (max-width:1180px){
  .card-grid-featured{grid-template-columns:repeat(3,minmax(0,1fr))}
  .testimonial-grid-carousel,.instagram-grid-carousel{grid-template-columns:repeat(2,minmax(0,1fr))}
  .carousel-arrow.prev{left:-6px}
  .carousel-arrow.next{right:-6px}
}
@media (max-width:820px){
  .hero-slide .hero-grid{min-height:auto}
}
@media (max-width:680px){
  .card-grid-featured,.testimonial-grid-carousel,.instagram-grid-carousel{grid-template-columns:1fr}
  .carousel-arrow{width:40px;height:40px}
}


/* v6 home layout and carousel controls */
.card-grid-featured{grid-template-columns:repeat(3,minmax(0,1fr))}
.blog-grid-home-carousel{grid-template-columns:repeat(3,minmax(0,1fr))}
.blog-home-card{padding:0;overflow:hidden;display:flex;flex-direction:column}
.blog-home-card__media{display:block}
.blog-home-card__media img{width:100%;aspect-ratio:16/10;object-fit:cover;margin:0;border-radius:0}
.blog-home-card__body{padding:20px;display:grid;gap:12px}
.blog-home-card__body h3{margin:0}
.blog-home-card__excerpt{color:var(--muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hero-main-carousel,.testimonials-carousel,.instagram-home-carousel,.blog-home-carousel{padding:0 54px}
.hero-main-carousel .carousel-arrow,.testimonials-carousel .carousel-arrow,.instagram-home-carousel .carousel-arrow,.blog-home-carousel .carousel-arrow{top:50%}
.hero-main-carousel .carousel-arrow.prev,.testimonials-carousel .carousel-arrow.prev,.instagram-home-carousel .carousel-arrow.prev,.blog-home-carousel .carousel-arrow.prev{left:0}
.hero-main-carousel .carousel-arrow.next,.testimonials-carousel .carousel-arrow.next,.instagram-home-carousel .carousel-arrow.next,.blog-home-carousel .carousel-arrow.next{right:0}
.hero-main-carousel .carousel-viewport{padding:24px 0 30px;margin:-24px 0 -30px}
.hero-main-carousel .carousel-page{padding:0 18px;box-sizing:border-box}
.product-thumb-carousel,.media-carousel,.modal-gallery{overflow:visible}
.thumb-nav,.carousel-nav{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.thumb-nav.prev,.carousel-nav.prev{left:-14px}
.thumb-nav.next,.carousel-nav.next{right:-14px}
@media (max-width:1180px){
  .card-grid-featured,.blog-grid-home-carousel{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero-main-carousel,.testimonials-carousel,.instagram-home-carousel,.blog-home-carousel{padding:0 42px}
  .hero-main-carousel .carousel-viewport{padding:22px 0 28px;margin:-22px 0 -28px}
  .hero-main-carousel .carousel-page{padding:0 12px}
  .hero-main-carousel .carousel-arrow.prev,.testimonials-carousel .carousel-arrow.prev,.instagram-home-carousel .carousel-arrow.prev,.blog-home-carousel .carousel-arrow.prev,.thumb-nav.prev,.carousel-nav.prev{left:-6px}
  .hero-main-carousel .carousel-arrow.next,.testimonials-carousel .carousel-arrow.next,.instagram-home-carousel .carousel-arrow.next,.blog-home-carousel .carousel-arrow.next,.thumb-nav.next,.carousel-nav.next{right:-6px}
}
@media (max-width:680px){
  .card-grid-featured,.testimonial-grid-carousel,.instagram-grid-carousel,.blog-grid-home-carousel{grid-template-columns:1fr}
  .hero-main-carousel,.testimonials-carousel,.instagram-home-carousel,.blog-home-carousel{padding:0 34px}
  .hero-main-carousel .carousel-viewport{padding:18px 0 24px;margin:-18px 0 -24px}
  .hero-main-carousel .carousel-page{padding:0 8px}
}

/* v7 carousel edge spacing fix */
.multi-card-carousel{overflow:visible}
.multi-card-carousel .carousel-viewport{
  overflow:hidden;
  padding:24px 18px 30px;
  margin:-24px -18px -30px;
}
.blog-home-carousel .carousel-page,
.testimonials-carousel .carousel-page,
.instagram-home-carousel .carousel-page{
  padding:0 12px;
  box-sizing:border-box;
}
.blog-home-card,
.testimonials-carousel .testimonial-card,
.instagram-home-carousel .instagram-card{
  box-shadow:0 14px 28px rgba(0,0,0,.05);
}
@media (max-width:1180px){
  .multi-card-carousel .carousel-viewport{
    padding:22px 14px 28px;
    margin:-22px -14px -28px;
  }
  .blog-home-carousel .carousel-page,
  .testimonials-carousel .carousel-page,
  .instagram-home-carousel .carousel-page{
    padding:0 10px;
  }
}
@media (max-width:680px){
  .multi-card-carousel .carousel-viewport{
    padding:18px 10px 24px;
    margin:-18px -10px -24px;
  }
  .blog-home-carousel .carousel-page,
  .testimonials-carousel .carousel-page,
  .instagram-home-carousel .carousel-page{
    padding:0 6px;
  }
}


/* v7 mobile carousel fixes */
@media (max-width: 680px){
  .hero-main-carousel,
  .blog-home-carousel,
  .testimonials-carousel,
  .instagram-home-carousel{
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .hero-main-carousel .carousel-viewport,
  .blog-home-carousel .carousel-viewport,
  .testimonials-carousel .carousel-viewport,
  .instagram-home-carousel .carousel-viewport{
    overflow: visible;
    padding-top: 12px !important;
    padding-bottom: 22px !important;
    margin-top: -12px !important;
    margin-bottom: -22px !important;
  }

  .hero-main-carousel .carousel-page,
  .blog-home-carousel .carousel-page,
  .testimonials-carousel .carousel-page,
  .instagram-home-carousel .carousel-page{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .blog-home-carousel .carousel-page > .blog-grid-home-carousel,
  .testimonials-carousel .carousel-page > .testimonial-grid-carousel,
  .instagram-home-carousel .carousel-page > .instagram-grid-carousel{
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .hero-slide .hero-grid{
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    align-items: start !important;
    min-height: 0 !important;
  }

  .hero-copy{
    max-width: 100%;
  }

  .hero-copy h1{
    font-size: clamp(34px, 10.2vw, 48px) !important;
    line-height: 0.96 !important;
    margin-bottom: 14px !important;
  }

  .hero-copy p{
    font-size: 16px !important;
    line-height: 1.55 !important;
    max-width: none !important;
  }

  .hero-media{
    order: -1;
  }

  .hero-media img{
    aspect-ratio: 4 / 3 !important;
    border-radius: 26px !important;
  }

  .hero-actions{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    width: 100% !important;
  }

  .hero-actions .btn{
    width: 100% !important;
  }

  .carousel-arrow{
    width: 38px !important;
    height: 38px !important;
    opacity: .78;
  }

  .blog-home-card,
  .testimonial-card,
  .instagram-card{
    min-width: 0;
    width: 100%;
  }
}

@media (max-width: 420px){
  .hero-copy h1{
    font-size: clamp(30px, 9.6vw, 40px) !important;
  }

  .hero-main-carousel,
  .blog-home-carousel,
  .testimonials-carousel,
  .instagram-home-carousel{
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
}


/* topo compacto: instagram só com ícone, carrinho com ícone + numeral, conta com primeiro nome */
.site-header .socials-store{gap:10px!important;flex:0 0 auto!important}
.site-header .socials-store .social-btn{padding:10px 14px!important;min-height:46px!important}
.site-header .socials-store .social-btn svg{flex:0 0 18px!important}
.site-header .socials-store .social-btn-instagram{width:46px!important;min-width:46px!important;padding:0!important;justify-content:center!important;gap:0!important}
.site-header .socials-store .social-btn-instagram .social-btn-label{display:none!important}
.site-header .socials-store .social-btn-cart-compact{position:relative!important;min-width:52px!important;width:52px!important;padding:0!important;justify-content:center!important;gap:0!important}
.site-header .socials-store .social-btn-cart-compact .social-btn-label{display:none!important}
.site-header .socials-store .social-btn-cart-compact .cart-badge{position:absolute!important;right:-4px!important;top:-4px!important;transform:none!important;min-width:20px!important;height:20px!important;font-size:11px!important;padding:0 5px!important}
.site-header .socials-store .social-btn-account{max-width:180px!important;padding-inline:14px!important}
.site-header .socials-store .social-btn-account span{display:inline-block!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;max-width:112px!important}
@media (max-width: 1180px){
  .site-header .nav-wrap{gap:12px!important}
  .site-header .nav{gap:18px!important}
  .site-header .socials-store{gap:8px!important}
  .site-header .socials-store .social-btn-account{max-width:150px!important}
  .site-header .socials-store .social-btn-account span{max-width:84px!important}
}


/* 2026-04-09 mobile UX polish: cleaner spacing, single-card focus, safer forms */
@media (max-width: 980px){
  .section{padding:56px 0 !important}
  .section-tight{padding-top:14px !important}
  .section-head{display:grid !important;gap:10px !important;align-items:start !important;margin-bottom:22px !important}
  .section-head h2{font-size:clamp(26px,7.2vw,40px) !important;line-height:1.04 !important}
  .section-head p{max-width:none !important;font-size:15px !important;line-height:1.6 !important}
  .feature-grid,.card-grid,.blog-grid,.testimonial-grid,.institution-grid{gap:16px !important}
  .feature-card,.product-card,.testimonial-card,.blog-card,.panel{padding:20px !important;border-radius:24px !important}
  .full-image-banner{min-height:300px !important;border-radius:28px !important;overflow:hidden !important}
  .full-image-banner__content{min-height:300px !important;padding:26px 20px !important}
  .full-image-banner__content h2{font-size:clamp(28px,8vw,46px) !important;line-height:1.02 !important}
  .institution-kofi{gap:18px !important}
  .kofi-showcase img{max-width:240px !important}
}

@media (max-width: 768px){
  .container{width:calc(100% - 28px) !important}
  .hero{padding-top:28px !important}
  .page-hero{padding-top:30px !important;padding-bottom:18px !important}
  .page-hero h1{font-size:clamp(30px,9vw,42px) !important;line-height:1.02 !important}
  .page-hero p{font-size:16px !important;line-height:1.6 !important}

  .section{padding:46px 0 !important}
  .section-head{margin-bottom:18px !important}

  .feature-card,.product-card,.testimonial-card,.blog-card,.panel,.checkout-block,.cart-summary,.empty-state{
    border-radius:22px !important;
    box-shadow:0 12px 28px rgba(17,17,17,.05) !important;
  }

  .product-card{gap:14px !important}
  .product-card .thumb{margin-bottom:0 !important;border-radius:18px !important}
  .product-card__body{gap:8px !important;margin-bottom:2px !important}
  .product-card__head h3{font-size:24px !important;line-height:1.06 !important}
  .product-card p{font-size:14px !important;line-height:1.55 !important}
  .product-card__actions{gap:10px !important}
  .product-card__actions .btn,
  .product-card__actions form > .btn{min-height:46px !important}

  .featured-more-cta{padding:18px !important;border-radius:22px !important;gap:14px !important}
  .featured-more-cta p{font-size:15px !important;line-height:1.55 !important}
  .featured-more-cta__button{min-height:48px !important}

  .blog-home-card__body,
  .instagram-home-carousel .instagram-card__body{padding:18px !important;gap:10px !important}
  .blog-home-card__media img{aspect-ratio:16/11 !important}
  .blog-home-card__excerpt,
  .instagram-home-carousel .instagram-card__body .rich-inline,
  .testimonial-card p{font-size:14px !important;line-height:1.6 !important}
  .testimonial-avatar{margin-bottom:12px !important}
  .testimonial-card strong{font-size:16px !important}

  .cart-layout,
  .store-shell,
  .checkout-onepage-layout{gap:18px !important}
  .cart-item{grid-template-columns:80px 1fr !important;gap:14px !important;padding:16px !important;border-radius:20px !important}
  .cart-item > :nth-child(3),
  .cart-item > :nth-child(4),
  .cart-item > :nth-child(5){grid-column:1 / -1 !important}
  .cart-item img{width:80px !important;height:80px !important;border-radius:16px !important;object-fit:cover !important}
  .cart-item-actions{display:grid !important;grid-template-columns:72px 1fr !important;gap:10px !important;align-items:end !important}
  .cart-item-actions label{grid-column:1 / -1 !important;margin:0 !important}
  .cart-line-total{font-size:18px !important;font-weight:800 !important}
  .cart-actions-row{display:grid !important;grid-template-columns:1fr !important;gap:10px !important}

  .checkout-onepage-head{gap:14px !important;margin-bottom:18px !important}
  .checkout-onepage-head h1{font-size:clamp(30px,8.8vw,42px) !important;margin:0 0 8px !important}
  .checkout-onepage-head p{font-size:15px !important;line-height:1.6 !important;margin:0 !important}
  .checkout-block{padding:18px !important;border-radius:22px !important}
  .checkout-block__header{margin-bottom:12px !important;gap:10px !important}
  .checkout-block__header h2{font-size:24px !important;line-height:1.08 !important}
  .checkout-field-grid{gap:12px !important}
  .checkout-field-grid label{gap:7px !important;font-size:13px !important}
  .checkout-option-list{gap:10px !important}
  .checkout-option-card{padding:14px !important;border-radius:18px !important;grid-template-columns:20px 1fr auto !important;align-items:start !important;gap:12px !important}
  .checkout-option-card strong{font-size:15px !important}
  .checkout-option-card span,
  .checkout-inline-note,
  .checkout-payment-note,
  .checkout-shipping-feedback{font-size:14px !important;line-height:1.55 !important}
  .checkout-coupon-box{grid-template-columns:1fr !important;gap:10px !important}
  .checkout-submit-row .btn,
  .btn-block{min-height:52px !important}

  .checkout-onepage-summary{padding:18px !important;border-radius:22px !important}
  .summary-line{font-size:14px !important}
  .summary-total{font-size:17px !important}
  .summary-line-top{padding:10px 0 !important}

  .site-header .nav{max-height:calc(100dvh - 112px) !important;overflow:auto !important}
}

@media (max-width: 680px){
  .container{width:calc(100% - 24px) !important}
  .site-header .nav-wrap{min-height:72px !important}
  .brand img{height:44px !important}
  .site-header .nav{top:82px !important;left:10px !important;right:10px !important;padding:16px !important;border-radius:18px !important;gap:2px !important}
  .site-header .nav a{padding:12px 10px !important;border-radius:12px !important}

  .hero-main-carousel,
  .blog-home-carousel,
  .testimonials-carousel,
  .instagram-home-carousel{padding-left:26px !important;padding-right:26px !important}
  .hero-main-carousel .carousel-viewport,
  .blog-home-carousel .carousel-viewport,
  .testimonials-carousel .carousel-viewport,
  .instagram-home-carousel .carousel-viewport{padding-top:10px !important;padding-bottom:20px !important;margin-top:-10px !important;margin-bottom:-20px !important}
  .hero-main-carousel .carousel-page,
  .blog-home-carousel .carousel-page,
  .testimonials-carousel .carousel-page,
  .instagram-home-carousel .carousel-page{padding:0 !important}
  .hero-main-carousel .carousel-arrow.prev,
  .blog-home-carousel .carousel-arrow.prev,
  .testimonials-carousel .carousel-arrow.prev,
  .instagram-home-carousel .carousel-arrow.prev{left:-2px !important}
  .hero-main-carousel .carousel-arrow.next,
  .blog-home-carousel .carousel-arrow.next,
  .testimonials-carousel .carousel-arrow.next,
  .instagram-home-carousel .carousel-arrow.next{right:-2px !important}
  .carousel-arrow{width:36px !important;height:36px !important}

  .hero-slide .hero-grid{gap:16px !important}
  .hero-copy h1{font-size:clamp(30px,9.8vw,42px) !important;margin-bottom:12px !important}
  .hero-copy p{font-size:15px !important}
  .hero-media img{border-radius:22px !important}
  .hero-actions{gap:10px !important}
  .hero-actions .btn{min-height:48px !important}

  .feature-grid,.card-grid-featured,.blog-grid-home-carousel,.testimonial-grid-carousel,.instagram-grid-carousel{gap:14px !important}
  .feature-card,.product-card,.testimonial-card,.blog-card,.panel,.checkout-block,.cart-summary,.empty-state{padding:18px !important}
  .instagram-home-carousel .instagram-card__media{aspect-ratio:1 / 1 !important;border-radius:18px 18px 0 0 !important;overflow:hidden !important}
  .blog-home-card,.instagram-card,.testimonial-card{width:100% !important;max-width:none !important}

  .testimonial-cta{padding:18px !important;border-radius:22px !important;gap:14px !important}
  .testimonial-cta .btn{width:100% !important;justify-content:center !important;min-height:48px !important}

  .footer-newsletter__content h3{font-size:22px !important}
  .footer-newsletter__content p,
  .footer-trust-copy,
  .footer-grid-redesign a,
  .footer-grid-redesign p{font-size:14px !important;line-height:1.55 !important}

  .koffie-chat-root{right:6px !important;bottom:12px !important}
}

@media (max-width: 430px){
  .container{width:calc(100% - 20px) !important}
  .section{padding:40px 0 !important}
  .feature-card,.product-card,.testimonial-card,.blog-card,.panel,.checkout-block,.cart-summary,.empty-state{padding:16px !important;border-radius:20px !important}
  .site-header .socials-store .social-btn,
  .site-header .menu-toggle{width:36px !important;height:36px !important;min-width:36px !important}
  .site-header .socials-store .social-btn svg{width:16px !important;height:16px !important}
  .hero-main-carousel,
  .blog-home-carousel,
  .testimonials-carousel,
  .instagram-home-carousel{padding-left:22px !important;padding-right:22px !important}
  .carousel-arrow{width:34px !important;height:34px !important}
}


/* 2026-04-09 mobile refinements requested after QA */
@media (max-width: 680px){
  /* carrosséis: 1 card visível com respiro real entre slides */
  .hero-main-carousel,
  .blog-home-carousel,
  .testimonials-carousel,
  .instagram-home-carousel{
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
  .hero-main-carousel .carousel-viewport,
  .blog-home-carousel .carousel-viewport,
  .testimonials-carousel .carousel-viewport,
  .instagram-home-carousel .carousel-viewport{
    overflow: hidden !important;
    padding-top: 10px !important;
    padding-bottom: 20px !important;
    margin-top: -10px !important;
    margin-bottom: -20px !important;
  }
  .hero-main-carousel .carousel-page,
  .blog-home-carousel .carousel-page,
  .testimonials-carousel .carousel-page,
  .instagram-home-carousel .carousel-page{
    padding: 0 10px !important;
    box-sizing: border-box !important;
  }
  .hero-main-carousel .carousel-page{padding:0 12px !important;}
  .hero-main-carousel .hero-slide{overflow:hidden !important;}
  .hero-main-carousel .hero-grid{margin:0 !important;}

  /* dots e CTA de depoimentos sem sobreposição */
  .testimonials-carousel .carousel-dots,
  .instagram-home-carousel .carousel-dots,
  .blog-home-carousel .carousel-dots,
  .hero-main-carousel .carousel-dots{
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    margin-top: 16px !important;
  }
  .testimonials-carousel .carousel-dots{margin-bottom:22px !important;}
  .testimonial-cta{margin-top:28px !important;}

  /* faixa de manifesto em largura total e sem cantos arredondados */
  .section-tight{padding-top:0 !important;}
  .full-image-banner{
    border-radius: 0 !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
  }
  .full-image-banner__content,
  .full-image-banner__overlay{border-radius:0 !important;}

  /* modal do produto com rolagem interna e botão fechar sempre visível */
  .modal{
    align-items: flex-start !important;
    overflow-y: auto !important;
    padding: calc(env(safe-area-inset-top, 0px) + 58px) 12px 16px !important;
  }
  .modal-box{
    position: relative !important;
    max-height: calc(100dvh - env(safe-area-inset-top, 0px) - 74px) !important;
    overflow: hidden !important;
    border-radius: 26px !important;
  }
  .modal-content,
  .modal-content-share{
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    max-height: 100% !important;
  }
  .close-modal{
    position: fixed !important;
    top: calc(env(safe-area-inset-top, 0px) + 10px) !important;
    right: 12px !important;
    z-index: 120 !important;
    width: 44px !important;
    height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    border: 1px solid rgba(0,0,0,.08) !important;
    box-shadow: 0 12px 28px rgba(0,0,0,.14) !important;
  }
  .modal-actions{padding-bottom:8px !important;}

  /* topo: botões perfeitamente circulares e iguais */
  .site-header .socials-store{gap:10px !important;}
  .site-header .socials-store .social-btn,
  .site-header .menu-toggle{
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    min-height: 46px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    justify-content: center !important;
    align-items: center !important;
    flex: 0 0 46px !important;
  }
  .site-header .socials-store .social-btn span:not(.cart-badge),
  .site-header .socials-store .social-btn .social-btn-label{display:none !important;}
  .site-header .socials-store .social-btn-account{max-width:none !important;}
  .site-header .socials-store .social-btn-cart-compact .cart-badge{
    right:-2px !important;
    top:-2px !important;
    min-width:20px !important;
    height:20px !important;
  }

  /* faixa do cupom mais compacta em uma linha */
  .site-coupon-banner{font-size:13px !important;}
  .site-coupon-banner .container{
    display:flex !important;
    flex-wrap:nowrap !important;
    justify-content:center !important;
    align-items:center !important;
    gap:10px !important;
    padding:10px 12px !important;
    overflow:hidden !important;
  }
  .site-coupon-banner .container span,
  .site-coupon-banner .container strong{
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  .site-coupon-banner .container span{font-size:13px !important;}
  .site-coupon-banner .container strong{font-size:13px !important;flex:0 0 auto !important;}
  .site-coupon-banner .btn{
    min-height:36px !important;
    padding:10px 14px !important;
    font-size:13px !important;
    flex:0 0 auto !important;
  }
}

@media (max-width: 430px){
  .hero-main-carousel,
  .blog-home-carousel,
  .testimonials-carousel,
  .instagram-home-carousel{padding-left:20px !important;padding-right:20px !important;}
  .hero-main-carousel .carousel-page,
  .blog-home-carousel .carousel-page,
  .testimonials-carousel .carousel-page,
  .instagram-home-carousel .carousel-page{padding:0 8px !important;}
  .site-coupon-banner .container span{font-size:12px !important;}
}

.coupon-banner-text-mobile{display:none}
@media (max-width:680px){
  .coupon-banner-text-desktop{display:none !important}
  .coupon-banner-text-mobile{display:inline !important}
}


/* v18 Segurança Site */
.admin-shortcut-card h3{word-break:break-word}
.table .input{min-height:36px}
.inline-form label input[type="checkbox"]{width:auto}


/* v21 Cliente 2FA */
.customer-2fa-option{display:flex!important;align-items:flex-start;gap:12px;padding:16px 18px;border:1px solid #eee;border-radius:18px;background:#fffdf8;cursor:pointer}
.customer-2fa-option input{width:18px!important;height:18px;min-width:18px;margin-top:3px}
.customer-2fa-option span{display:grid;gap:4px}
.customer-2fa-option strong{font-size:15px;color:#202020}
.customer-2fa-option small{display:block;color:#666;font-size:13px;line-height:1.45}

/* v4.0 - Produto: modal comercial configurável */
.product-modal-box{width:min(1080px,calc(100vw - 40px));grid-template-columns:minmax(360px,.95fr) minmax(380px,1.05fr)!important;gap:28px;padding:20px!important;overflow:hidden!important}
.product-modal-close{position:absolute;top:16px;right:16px;z-index:4;width:38px;height:38px;border-radius:50%;border:1px solid rgba(0,0,0,.08);background:#fff;box-shadow:0 12px 28px rgba(0,0,0,.12);font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.product-modal-gallery{min-height:420px;border-radius:22px;background:#f4f4f4;overflow:hidden!important;display:flex;align-items:center;justify-content:center}
.product-modal-gallery img{width:100%;height:100%;object-fit:contain;padding:10px}
.product-modal-content{gap:18px!important;padding:14px 8px 14px 0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch}
.product-modal-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:start}
.product-modal-head h2{margin:0!important;font-size:clamp(30px,3vw,44px)!important;line-height:1!important;letter-spacing:-.045em!important}
.product-modal-subtitle{margin:8px 0 0;color:#6c6258;font-size:15px;font-weight:700}
.product-modal-pricebox{display:grid;gap:5px;text-align:right;white-space:nowrap;padding-top:2px}
.product-modal-pricebox strong{font-size:26px;color:#272019;letter-spacing:-.02em}
.product-modal-pricebox span{font-size:13px;color:#8a4a20;font-weight:800;background:#fff7f1;border:1px solid #efd8c7;border-radius:999px;padding:6px 10px}
.product-modal-pricebox small{font-size:12px;color:#8a8076;font-weight:700}
.product-modal-desc p{margin:0 0 8px;line-height:1.68}.product-modal-desc p:last-child{margin-bottom:0}
.product-modal-block{border:1px solid #ece4db;background:#fffaf6;border-radius:18px;padding:14px 15px}
.product-modal-block h3{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:#796a5c}
.product-modal-chips{display:flex;gap:8px;flex-wrap:wrap}
.product-modal-chips span{display:inline-flex;align-items:center;min-height:32px;padding:8px 11px;border-radius:999px;background:#fff;border:1px solid #eadfd3;color:#3e332b;font-size:13px;font-weight:700}
.product-modal-two-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.product-modal-text p{margin:0 0 7px;color:#5d5349;font-size:14px;line-height:1.55}.product-modal-text p:last-child{margin-bottom:0}
.product-modal-note{border:1px solid #e7edf2;background:#f8fbfd;border-radius:16px;padding:12px 14px;color:#4b5563;font-size:13px;line-height:1.5}
.product-modal-actions{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.82),#fff 28%);padding-top:12px!important;margin-top:0!important;z-index:2}
.product-modal-qty{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fbf8f4;border:1px solid #ece2d6;border-radius:18px;padding:10px 12px}
.product-modal-qty label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#8a7767;font-weight:800}
.qty-control{display:inline-flex;align-items:center;border:1px solid #d9cec2;border-radius:999px;background:#fff;overflow:hidden;min-height:40px}
.qty-control button{width:40px;height:40px;border:0;background:#fff;font-size:18px;font-weight:800;cursor:pointer;color:#272019}.qty-control button:hover{background:#f7f0e9}
.qty-control input{width:52px;border:0;text-align:center;font-weight:800;color:#272019;background:#fff;appearance:textfield}.qty-control input::-webkit-outer-spin-button,.qty-control input::-webkit-inner-spin-button{appearance:none;margin:0}
.product-modal-link{background:#fff!important;color:#2a221c!important;border-color:#e2d8cb!important}
@media (max-width:980px){.product-modal-box{grid-template-columns:1fr!important;width:min(720px,calc(100vw - 24px));max-height:calc(100dvh - 32px)!important;overflow:auto!important}.product-modal-gallery{min-height:auto;aspect-ratio:1/1}.product-modal-content{padding:4px 2px 8px!important;overflow:visible!important}.product-modal-head{grid-template-columns:1fr}.product-modal-pricebox{text-align:left;white-space:normal;justify-items:start}.product-modal-two-cols{grid-template-columns:1fr}.product-modal-actions{position:sticky;bottom:-1px}.product-modal-close{display:flex}}
@media (max-width:640px){.product-modal-box{width:calc(100vw - 18px)!important;border-radius:24px!important;padding:14px!important;gap:16px}.product-modal-gallery{border-radius:18px}.product-modal-head h2{font-size:31px!important}.product-modal-content{gap:14px!important}.product-modal-chips{display:grid;grid-template-columns:1fr}.product-modal-chips span{border-radius:14px}.product-modal-actions .btn{min-height:48px}.product-modal-qty{align-items:flex-start;flex-direction:column}.qty-control{width:100%;justify-content:space-between}.qty-control input{flex:1}.close-modal{display:none!important}.product-modal-close{top:10px;right:10px}}


/* Correção modal produto — fechamento, miniaturas e rolagem mobile */
.product-modal-box{position:relative!important;overflow:visible!important}
.product-modal-close{top:-18px!important;right:-18px!important;z-index:8!important}
.product-modal-head{padding-right:10px}
.product-modal-link[hidden]{display:none!important}
.product-modal-gallery{position:relative;flex-direction:column;gap:12px;padding-bottom:16px!important;overflow:visible!important}
.product-modal-gallery>[data-modal-image]{flex:1;min-height:0}
.product-modal-thumbs{position:relative!important;left:auto!important;right:auto!important;bottom:auto!important;display:flex!important;justify-content:center!important;align-items:center!important;gap:8px!important;margin-top:4px!important;width:100%!important}
.product-modal-thumbs button{width:44px!important;height:44px!important;border-radius:12px!important;padding:2px!important;border:1px solid #ddd!important;background:#fff!important;opacity:.65!important;overflow:hidden!important;box-shadow:none!important;cursor:pointer!important}
.product-modal-thumbs button.active{opacity:1!important;border-color:var(--red)!important;box-shadow:0 0 0 2px rgba(212,40,47,.12)!important}
.product-modal-thumbs button img{width:100%!important;height:100%!important;object-fit:cover!important;border-radius:9px!important;padding:0!important;aspect-ratio:auto!important}
#productModal.modal.show{overflow-y:auto!important;-webkit-overflow-scrolling:touch!important}
@media (max-width:980px){
  #productModal.modal{align-items:flex-start!important;justify-content:flex-start!important;padding:16px 10px 28px!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important}
  #productModal.modal.show{display:block!important}
  .product-modal-box{width:min(720px,calc(100vw - 20px))!important;max-height:none!important;min-height:auto!important;margin:36px auto 28px!important;overflow:visible!important;display:grid!important;grid-template-columns:1fr!important}
  .product-modal-content{overflow:visible!important;max-height:none!important;padding:4px 2px 12px!important}
  .product-modal-gallery{aspect-ratio:auto!important;min-height:auto!important;padding:12px 12px 16px!important}
  .product-modal-gallery>[data-modal-image]{height:auto!important;max-height:58vh!important;object-fit:contain!important}
  .product-modal-close{position:fixed!important;top:calc(env(safe-area-inset-top,0px) + 12px)!important;right:16px!important;width:54px!important;height:54px!important;font-size:34px!important;z-index:1305!important;color:#1473e6!important;border:0!important;box-shadow:0 14px 38px rgba(0,0,0,.18)!important}
  .product-modal-actions{position:relative!important;bottom:auto!important;background:#fff!important;padding-top:6px!important}
}
@media (max-width:640px){
  .product-modal-box{width:calc(100vw - 18px)!important;border-radius:26px!important;padding:12px!important;margin-top:78px!important}
  .product-modal-head h2{font-size:34px!important;line-height:.96!important}
  .product-modal-pricebox strong{font-size:32px!important}
  .product-modal-thumbs button{width:36px!important;height:36px!important;border-radius:10px!important}
  .product-modal-gallery>[data-modal-image]{max-height:none!important;width:100%!important}
}

/* v4.0.2 - Correção final de rolagem do modal de produto no mobile/iOS/Android */
@media (max-width: 980px){
  body.modal-is-open{
    overflow: hidden !important;
    height: 100% !important;
    touch-action: none;
  }
  #productModal.modal,
  #productModal.modal.show{
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100svh !important;
    height: 100dvh !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
    overflow: hidden !important;
    padding: calc(env(safe-area-inset-top, 0px) + 78px) 10px calc(env(safe-area-inset-bottom, 0px) + 18px) !important;
    -webkit-overflow-scrolling: auto !important;
  }
  #productModal .product-modal-box{
    width: min(720px, calc(100vw - 20px)) !important;
    max-width: min(720px, calc(100vw - 20px)) !important;
    max-height: calc(100svh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 108px) !important;
    max-height: calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 108px) !important;
    margin: 0 auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    touch-action: pan-y !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  #productModal .product-modal-content{
    overflow: visible !important;
    max-height: none !important;
    touch-action: pan-y !important;
  }
  #productModal .product-modal-gallery{
    aspect-ratio: auto !important;
    min-height: 0 !important;
    max-height: none !important;
  }
  #productModal .product-modal-gallery > [data-modal-image]{
    width: 100% !important;
    height: auto !important;
    max-height: 50svh !important;
    max-height: 50dvh !important;
    object-fit: contain !important;
  }
  #productModal .product-modal-actions{
    position: relative !important;
    bottom: auto !important;
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 10px) !important;
  }
  #productModal .product-modal-close{
    position: fixed !important;
    top: calc(env(safe-area-inset-top, 0px) + 12px) !important;
    right: 16px !important;
    z-index: 1305 !important;
    touch-action: manipulation !important;
  }
}
@media (max-width: 640px){
  #productModal.modal,
  #productModal.modal.show{
    padding-top: calc(env(safe-area-inset-top, 0px) + 72px) !important;
  }
  #productModal .product-modal-box{
    width: calc(100vw - 18px) !important;
    max-width: calc(100vw - 18px) !important;
    max-height: calc(100svh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 96px) !important;
    max-height: calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 96px) !important;
    border-radius: 26px !important;
  }
  #productModal .product-modal-gallery > [data-modal-image]{
    max-height: 46svh !important;
    max-height: 46dvh !important;
  }
  #productModal .product-modal-head h2{
    font-size: 31px !important;
    line-height: .98 !important;
  }
}

/* v4.0.3 - Correção definitiva: rolagem do modal de produto pelo overlay no mobile/iOS/Android */
@media (max-width: 980px){
  body.modal-is-open{
    overflow: hidden !important;
    height: auto !important;
    position: static !important;
    touch-action: auto !important;
  }
  #productModal.modal,
  #productModal.modal.show{
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100svh !important;
    height: 100dvh !important;
    display: block !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-y: contain !important;
    touch-action: pan-y !important;
    padding: calc(env(safe-area-inset-top, 0px) + 78px) 10px calc(env(safe-area-inset-bottom, 0px) + 34px) !important;
  }
  #productModal .product-modal-box{
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: min(720px, calc(100vw - 20px)) !important;
    max-width: min(720px, calc(100vw - 20px)) !important;
    height: auto !important;
    min-height: auto !important;
    max-height: none !important;
    margin: 0 auto !important;
    overflow: visible !important;
    -webkit-overflow-scrolling: auto !important;
    touch-action: pan-y !important;
  }
  #productModal .product-modal-content{
    overflow: visible !important;
    max-height: none !important;
    height: auto !important;
    touch-action: pan-y !important;
  }
  #productModal .product-modal-gallery{
    aspect-ratio: auto !important;
    min-height: auto !important;
    max-height: none !important;
    touch-action: pan-y pinch-zoom !important;
  }
  #productModal .product-modal-gallery > [data-modal-image]{
    width: 100% !important;
    height: auto !important;
    max-height: 50svh !important;
    max-height: 50dvh !important;
    object-fit: contain !important;
  }
  #productModal .product-modal-actions{
    position: relative !important;
    bottom: auto !important;
    background: #fff !important;
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 12px) !important;
  }
  #productModal .product-modal-close{
    position: fixed !important;
    top: calc(env(safe-area-inset-top, 0px) + 12px) !important;
    right: 16px !important;
    z-index: 1305 !important;
    touch-action: manipulation !important;
  }
}
@media (max-width: 640px){
  #productModal.modal,
  #productModal.modal.show{
    padding-top: calc(env(safe-area-inset-top, 0px) + 72px) !important;
    padding-left: 9px !important;
    padding-right: 9px !important;
  }
  #productModal .product-modal-box{
    width: calc(100vw - 18px) !important;
    max-width: calc(100vw - 18px) !important;
    border-radius: 26px !important;
  }
  #productModal .product-modal-gallery > [data-modal-image]{
    max-height: 44svh !important;
    max-height: 44dvh !important;
  }
  #productModal .product-modal-head h2{
    font-size: 30px !important;
    line-height: .98 !important;
  }
  #productModal .product-modal-pricebox strong{
    font-size: 28px !important;
  }
}

/* v4.0.4 - Correção segura do modal de produto no mobile
   Objetivo: manter desktop estável, restaurar rolagem interna real no card no iOS/Android
   e impedir campos de variação vazios/hidden de aparecerem. */
#productModal [hidden],
#productModal .grind-field[hidden],
#productModal .variation-field[hidden],
#productModal .product-modal-link[hidden],
#productModal .product-modal-subtitle[hidden],
#productModal .product-modal-pricebox span[hidden],
#productModal .product-modal-block[hidden],
#productModal .product-modal-note[hidden]{
  display:none!important;
}
#productModal .product-modal-link:not([href]),
#productModal .product-modal-link[href="#"]{
  display:none!important;
}
#productModal .product-modal-box{
  overscroll-behavior:contain;
}

@media (max-width: 760px){
  body.modal-is-open{
    overflow:hidden!important;
    touch-action:auto!important;
  }
  #productModal.modal,
  #productModal.modal.show{
    position:fixed!important;
    inset:0!important;
    width:100vw!important;
    height:100dvh!important;
    max-height:100dvh!important;
    padding:10px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    overflow:hidden!important;
    -webkit-overflow-scrolling:auto!important;
    touch-action:none!important;
  }
  #productModal .product-modal-box{
    width:calc(100vw - 18px)!important;
    max-width:calc(100vw - 18px)!important;
    height:auto!important;
    max-height:calc(100dvh - 24px)!important;
    min-height:0!important;
    margin:0 auto!important;
    padding:12px!important;
    border-radius:26px!important;
    display:block!important;
    grid-template-columns:1fr!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    -webkit-overflow-scrolling:touch!important;
    touch-action:pan-y!important;
    overscroll-behavior:contain!important;
  }
  #productModal .product-modal-gallery{
    width:100%!important;
    min-height:0!important;
    height:auto!important;
    max-height:none!important;
    aspect-ratio:auto!important;
    padding:10px 10px 14px!important;
    border-radius:20px!important;
    display:flex!important;
    flex-direction:column!important;
    gap:10px!important;
    overflow:hidden!important;
  }
  #productModal .product-modal-gallery > [data-modal-image]{
    width:100%!important;
    height:auto!important;
    max-height:38dvh!important;
    min-height:180px!important;
    object-fit:contain!important;
    aspect-ratio:auto!important;
    padding:0!important;
    border-radius:18px!important;
  }
  #productModal .product-modal-content{
    padding:18px 8px 18px!important;
    display:flex!important;
    flex-direction:column!important;
    gap:14px!important;
    overflow:visible!important;
    max-height:none!important;
    touch-action:pan-y!important;
  }
  #productModal .product-modal-head{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    padding-right:0!important;
  }
  #productModal .product-modal-head h2{
    font-size:clamp(28px, 9vw, 38px)!important;
    line-height:.98!important;
    letter-spacing:-.045em!important;
    margin:0!important;
  }
  #productModal .product-modal-pricebox{
    text-align:left!important;
    justify-items:start!important;
    white-space:normal!important;
  }
  #productModal .product-modal-pricebox strong{
    font-size:32px!important;
  }
  #productModal .product-modal-desc,
  #productModal .product-modal-desc p{
    font-size:16px!important;
    line-height:1.58!important;
  }
  #productModal .product-modal-two-cols{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:12px!important;
  }
  #productModal .product-modal-actions{
    position:relative!important;
    bottom:auto!important;
    background:#fff!important;
    padding:4px 0 0!important;
    margin-top:0!important;
    display:flex!important;
    flex-direction:column!important;
    gap:10px!important;
    z-index:1!important;
  }
  #productModal .product-modal-actions form,
  #productModal .product-modal-actions .btn{
    width:100%!important;
  }
  #productModal .product-modal-qty{
    width:100%!important;
    margin-bottom:10px!important;
  }
  #productModal .qty-control{
    width:100%!important;
    justify-content:space-between!important;
  }
  #productModal .product-modal-close{
    position:fixed!important;
    top:calc(env(safe-area-inset-top,0px) + 78px)!important;
    right:14px!important;
    width:54px!important;
    height:54px!important;
    border-radius:999px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    color:#1473e6!important;
    background:#fff!important;
    box-shadow:0 14px 38px rgba(0,0,0,.2)!important;
    z-index:1305!important;
    font-size:34px!important;
    line-height:1!important;
    border:0!important;
  }
  #productModal > .close-modal{
    display:none!important;
  }
}

@media (max-width: 390px){
  #productModal .product-modal-gallery > [data-modal-image]{
    max-height:34dvh!important;
    min-height:160px!important;
  }
  #productModal .product-modal-head h2{
    font-size:30px!important;
  }
}

/* v4.0.5 - Correção crítica: o modal de produto só pode aparecer quando tiver .show.
   Corrige iOS/Android: modal em branco travando a página e X sem ação. */
@media (max-width: 980px){
  #productModal.modal:not(.show){
    display:none!important;
    visibility:hidden!important;
    opacity:0!important;
    pointer-events:none!important;
  }
  #productModal.modal.show{
    display:flex!important;
    visibility:visible!important;
    opacity:1!important;
    pointer-events:auto!important;
    position:fixed!important;
    inset:0!important;
    width:100vw!important;
    height:100dvh!important;
    max-height:100dvh!important;
    padding:10px!important;
    align-items:center!important;
    justify-content:center!important;
    overflow:hidden!important;
    touch-action:auto!important;
    -webkit-overflow-scrolling:auto!important;
  }
  body.modal-is-open{
    overflow:hidden!important;
  }
  #productModal.modal.show .product-modal-box{
    width:min(720px, calc(100vw - 18px))!important;
    max-width:calc(100vw - 18px)!important;
    max-height:calc(100dvh - 24px)!important;
    height:auto!important;
    min-height:0!important;
    margin:0 auto!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    -webkit-overflow-scrolling:touch!important;
    overscroll-behavior:contain!important;
    touch-action:pan-y!important;
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  #productModal.modal.show .product-modal-content{
    overflow:visible!important;
    max-height:none!important;
    height:auto!important;
    touch-action:pan-y!important;
  }
  #productModal.modal.show .product-modal-gallery{
    min-height:0!important;
    height:auto!important;
    max-height:none!important;
    aspect-ratio:auto!important;
    overflow:hidden!important;
  }
  #productModal.modal.show .product-modal-gallery > [data-modal-image]{
    width:100%!important;
    height:auto!important;
    max-height:38dvh!important;
    min-height:0!important;
    object-fit:contain!important;
  }
  #productModal.modal.show .product-modal-actions{
    position:relative!important;
    bottom:auto!important;
    background:#fff!important;
    padding-bottom:calc(env(safe-area-inset-bottom,0px) + 8px)!important;
  }
  #productModal.modal.show .product-modal-close{
    position:fixed!important;
    top:calc(env(safe-area-inset-top,0px) + 78px)!important;
    right:14px!important;
    z-index:1400!important;
    pointer-events:auto!important;
    touch-action:manipulation!important;
  }
  #productModal.modal.show > .close-modal{
    display:none!important;
  }
}
@media (max-width: 640px){
  #productModal.modal.show .product-modal-box{
    width:calc(100vw - 18px)!important;
    max-width:calc(100vw - 18px)!important;
    max-height:calc(100dvh - 24px)!important;
    border-radius:26px!important;
    padding:12px!important;
  }
  #productModal.modal.show .product-modal-gallery > [data-modal-image]{
    max-height:34dvh!important;
  }
  #productModal.modal.show .product-modal-head h2{
    font-size:clamp(28px, 8.5vw, 36px)!important;
  }
}


/* v4.0.6 - Correção do modal de cupom no mobile/iOS/Android */
.coupon-modal:not(.show){
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
.coupon-modal.show{
  display:flex!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
}
.coupon-modal .coupon-modal-box{
  position:relative;
}
.coupon-modal .coupon-modal-close{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  cursor:pointer;
  z-index:10;
}
@media (max-width: 980px){
  .coupon-modal.show{
    position:fixed!important;
    inset:0!important;
    width:100vw!important;
    height:100dvh!important;
    max-height:100dvh!important;
    padding:10px!important;
    align-items:center!important;
    justify-content:center!important;
    overflow:hidden!important;
    touch-action:auto!important;
    -webkit-overflow-scrolling:auto!important;
    z-index:1400!important;
  }
  .coupon-modal.show .coupon-modal-box{
    width:min(720px, calc(100vw - 18px))!important;
    max-width:calc(100vw - 18px)!important;
    max-height:calc(100dvh - 24px)!important;
    height:auto!important;
    min-height:0!important;
    margin:0 auto!important;
    border-radius:28px!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    -webkit-overflow-scrolling:touch!important;
    overscroll-behavior:contain!important;
    touch-action:pan-y!important;
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .coupon-modal.show .coupon-modal-media{
    max-height:36dvh!important;
    overflow:hidden!important;
  }
  .coupon-modal.show .coupon-modal-media img{
    width:100%!important;
    height:auto!important;
    max-height:36dvh!important;
    object-fit:cover!important;
  }
  .coupon-modal.show .coupon-modal-content{
    padding:24px 20px calc(env(safe-area-inset-bottom,0px) + 24px)!important;
    overflow:visible!important;
    max-height:none!important;
    height:auto!important;
    touch-action:pan-y!important;
  }
  .coupon-modal.show .coupon-modal-close{
    position:fixed!important;
    top:calc(env(safe-area-inset-top,0px) + 74px)!important;
    right:14px!important;
    width:62px!important;
    height:62px!important;
    border-radius:999px!important;
    background:#fff!important;
    color:#1473e6!important;
    box-shadow:0 14px 38px rgba(0,0,0,.2)!important;
    z-index:1500!important;
    font-size:34px!important;
    line-height:1!important;
    border:0!important;
    pointer-events:auto!important;
    touch-action:manipulation!important;
  }
  .coupon-modal.show .coupon-popup-form,
  .coupon-modal.show .coupon-popup-form .btn,
  .coupon-modal.show .btn-ghost{
    width:100%!important;
  }
}
@media (max-width: 640px){
  .coupon-modal.show{
    padding:8px!important;
  }
  .coupon-modal.show .coupon-modal-box{
    width:calc(100vw - 16px)!important;
    max-width:calc(100vw - 16px)!important;
    max-height:calc(100dvh - 20px)!important;
    border-radius:26px!important;
  }
  .coupon-modal.show .coupon-modal-content h2{
    font-size:clamp(28px, 8vw, 36px)!important;
    line-height:1.05!important;
    letter-spacing:-.04em!important;
  }
  .coupon-modal.show .coupon-code-box{
    word-break:break-word!important;
  }
}
