﻿/*
Theme Name: Rovellart
Theme URI: https://www.espairovellart.com
Author: Redisseny
Description: Tema a mida per a Espai Rovellart â€” galeria d'art en ferro reciclat. Minimalista, blanc i elegant.
Version: 1.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: rovellart
*/

:root{
  --ink:#1d1d1b;--muted:#8a8a86;--line:#e6dece;--accent:#0b7c85;--bg:#f9f6f0;--soft:#f1ece1;--frame:#1a1a1a;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--frame)}
body{font-family:'Jost',system-ui,sans-serif;color:var(--ink);background:var(--frame);font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased}
/* layout emmarcat (passepartout) */
.r-site{max-width:1480px;margin:0 auto;background:var(--bg);position:relative;box-shadow:0 0 70px rgba(0,0,0,.4)}
h1,h2,h3,.serif{font-family:'Playfair Display',Georgia,serif;font-weight:400;letter-spacing:.2px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.label{font-size:11px;letter-spacing:3.5px;text-transform:uppercase;color:var(--muted);font-weight:400}

/* top bar */
.r-topbar{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line)}
.r-topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.r-langs span{margin-left:14px;cursor:pointer}.r-langs .on{color:var(--accent)}

/* header */
.r-header{position:sticky;top:0;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);z-index:30}
body.admin-bar .r-header{top:32px}
@media screen and (max-width:782px){body.admin-bar .r-header{top:46px}}
.r-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:28px;height:88px}
.r-brand{font-family:'Playfair Display',serif;display:flex;align-items:center;gap:13px;text-decoration:none;flex:0 0 auto}
.r-emblem{height:52px;width:52px;display:block;border-radius:50%}
.r-wordmark{font-size:28px;letter-spacing:.5px;color:var(--ink);line-height:1;white-space:nowrap}
.r-wordmark b{color:var(--accent);font-weight:600}
@media(max-width:860px){.r-emblem{height:46px;width:46px}.r-wordmark{font-size:25px}}
.r-nav ul{display:flex;gap:34px;list-style:none;flex-wrap:nowrap}
.r-nav a{font-size:12.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--ink);position:relative;padding:4px 0;white-space:nowrap}
.r-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--accent);transition:.3s}
.r-nav a:hover::after{width:100%}
.r-cart{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;white-space:nowrap;flex:0 0 auto}
.r-burger{display:none;background:none;border:0;font-size:26px;line-height:1;cursor:pointer;color:var(--ink);padding:4px}
.r-nav-cart{display:none}

/* hero */
.r-hero{position:relative;height:80vh;min-height:520px;overflow:hidden;background:#000;border-radius:28px;margin:16px 16px 0}
.r-hero img{width:100%;height:100%;object-fit:cover;opacity:.82;transform:scale(1.0);transform-origin:center}
.r-hero .ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding-left:8%;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.65);background:linear-gradient(90deg,rgba(0,0,0,.72),rgba(0,0,0,.42) 45%,rgba(0,0,0,.08) 80%,rgba(0,0,0,0))}
.r-hero .label{color:rgba(255,255,255,.85)}
.r-hero h1{font-size:clamp(40px,6vw,84px);line-height:1.05;max-width:14ch;margin:18px 0 26px}
.r-hero p{max-width:40ch;font-size:17px;color:rgba(255,255,255,.92);margin-bottom:34px}
.btn{display:inline-block;border:1px solid #fff;color:#fff;padding:15px 40px;border-radius:40px;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;transition:.3s;cursor:pointer}
.btn:hover{background:#fff;color:var(--ink)}
.btn.dark{border-color:var(--ink);color:var(--ink)}
.btn.dark:hover{background:var(--ink);color:#fff}

/* sections */
.sec{padding:110px 0}
.sec-head{text-align:center;margin-bottom:60px}
.sec-head h2{font-size:clamp(30px,4vw,46px);margin-top:12px}
.sec-head .line{width:46px;height:1px;background:var(--accent);margin:22px auto 0}

/* product grid */
.r-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px 28px}
.r-piece{display:block}
.r-piece .ph{overflow:hidden;background:var(--soft);aspect-ratio:4/3;border-radius:18px}
.r-piece .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s ease}
.r-piece:hover .ph img{transform:scale(1.06)}
.r-piece .meta{padding:16px 2px 8px}
.r-piece .name{font-family:'Playfair Display',serif;font-size:23px;font-style:italic;color:var(--ink)}
.r-piece .spec{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:4px}
.r-piece .price{display:none}
.r-cta-link{margin-top:12px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--accent);opacity:0;transform:translateY(5px);transition:opacity .35s ease,transform .35s ease}
.r-piece:hover .r-cta-link{opacity:1;transform:none}
@media(max-width:860px){.r-cta-link{opacity:1;transform:none}}
.more{text-align:center;margin-top:64px}

/* artist */
.r-artist{background:var(--soft)}
.r-artist .wrap{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;padding:96px 32px}
.r-artist .txt h2{font-size:clamp(28px,3.5vw,42px);margin:14px 0 22px;line-height:1.15}
.r-artist .txt p{color:#4a4a47;margin-bottom:18px;max-width:46ch}
.r-artist .ph{aspect-ratio:4/5;overflow:hidden;background:#eee;border-radius:24px}
.r-artist .ph img{width:100%;height:100%;object-fit:cover}
.sign{font-family:'Playfair Display',serif;font-style:italic;font-size:26px;color:var(--accent);margin-top:8px}

/* trust */
.r-trust .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:40px 32px 100px;text-align:center}
.r-trust .wrap>div{background:var(--soft);border-radius:24px;padding:46px 28px}
.r-trust .ic{font-size:26px;color:var(--accent);margin-bottom:14px}
.r-trust h4{font-family:'Jost';font-weight:400;font-size:13px;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.r-trust p{font-size:14px;color:var(--muted);max-width:30ch;margin:0 auto}

/* footer */
.r-footer{background:#15201f;color:#cdd6d4;padding:80px 0 36px}
.r-footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:50px;margin-bottom:50px}
.r-footer .r-brand{color:#fff;margin-bottom:18px}
.r-footer p{font-size:14px;color:#9fb0ad;max-width:34ch}
.r-footer h5{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:#6f8783;margin-bottom:18px}
.r-footer ul{list-style:none}
.r-footer li{margin-bottom:11px;font-size:14px}
.r-footer li a{color:#cdd6d4}.r-footer li a:hover{color:#fff}
.r-copy{border-top:1px solid #2a3736;padding-top:26px;font-size:12px;letter-spacing:1px;color:#6f8783;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* generic woo pages wrapper */
.r-page{padding:70px 0 100px;min-height:50vh}
.r-page .page-title{text-align:center;font-size:clamp(32px,4vw,52px);margin-bottom:40px}

/* contact page */
.rc-wrap{padding:70px 0 100px}
.rc-head{text-align:center;margin-bottom:54px}
.rc-head h1{font-size:clamp(34px,4.5vw,56px);margin-top:12px}
.rc-head p{color:var(--muted);max-width:48ch;margin:16px auto 0}
.rc-hero{position:relative;height:46vh;min-height:300px;overflow:hidden;background:#000;border-radius:28px;margin:16px 16px 0}
.rc-hero img{width:100%;height:100%;object-fit:cover;opacity:.85;transform:scale(1.0);transform-origin:center}
.rc-hero-ov{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.6);background:rgba(0,0,0,.42)}
.rc-hero-ov .label{color:rgba(255,255,255,.85)}
.rc-hero-ov h1{font-size:clamp(34px,5vw,60px);margin-top:10px}
.rc-intro{text-align:center;color:var(--muted);max-width:48ch;margin:0 auto 54px}
@media(max-width:860px){.rc-hero{height:40vh;min-height:240px;margin:10px 10px 0}}
.rc-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start}
.rc-info .blk{margin-bottom:30px}
.rc-info h3{font-family:'Playfair Display',serif;font-weight:400;font-size:24px;margin-bottom:6px}
.rc-info p{color:#4a4a47}
.rc-info a{color:var(--accent)}
.rc-form{background:var(--soft);border-radius:26px;padding:40px}
.rc-form input[type=text],.rc-form input[type=email],.rc-form input[type=tel],.rc-form input[type=url],.rc-form textarea,.rc-form select{width:100%;border:1px solid var(--line);background:#fff;border-radius:14px;padding:14px 16px;font-family:'Jost';font-size:15px;font-weight:300;margin-bottom:18px;color:var(--ink)}
.rc-form textarea{min-height:130px;resize:vertical}
.rc-form label{display:block;font-size:12px;letter-spacing:1px;color:#5a5a57;margin-bottom:6px}
.rc-form .wpcf7-submit,.rc-form input[type=submit],.rc-form button[type=submit]{background:var(--ink);color:#fff;border:none;border-radius:40px;padding:16px;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;width:100%;transition:.3s;margin-top:4px}
.rc-form .wpcf7-submit:hover,.rc-form input[type=submit]:hover{background:var(--accent)}
@media(max-width:860px){.rc-grid{grid-template-columns:1fr;gap:34px}}
/* mapa */
.r-map{max-width:1240px;margin:0 auto;padding:0 16px 80px}
.r-map iframe{width:100%;height:380px;border:0;border-radius:20px;display:block}
@media(max-width:860px){.r-map iframe{height:300px}}

/* exposicions */
.rx-wrap{padding:70px 0 100px}
.rx-head{text-align:center;margin-bottom:56px}
.rx-head h1{font-size:clamp(34px,4.5vw,56px);margin-top:12px}
.rx-head p{color:var(--muted);max-width:54ch;margin:16px auto 0}
.rx-list{max-width:880px;margin:0 auto}
.rx-item{display:flex;gap:28px;align-items:center;padding:22px 4px;border-bottom:1px solid var(--line)}
.rx-item:first-child{border-top:1px solid var(--line)}
.rx-year{font-family:'Playfair Display',serif;font-size:28px;color:var(--accent);min-width:62px;flex-shrink:0}
.rx-thumb{width:72px;height:96px;flex-shrink:0;background:var(--soft);border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.rx-thumb img{width:100%;height:100%;object-fit:cover}
.rx-info h3{font-family:'Playfair Display',serif;font-weight:400;font-style:italic;font-size:24px;margin:0 0 4px}
.rx-info span{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.rx-cta{text-align:center;margin-top:60px}
@media(max-width:860px){.rx-item{gap:16px}.rx-year{min-width:46px;font-size:21px}.rx-thumb{width:56px;height:74px}}

@media(max-width:860px){
  .r-cart{display:none}
  .r-burger{display:block}
  .r-header .wrap{position:relative;height:82px}
  .r-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 14px 26px rgba(0,0,0,.07)}
  .r-nav.open{display:block}
  .r-nav ul{flex-direction:column;gap:0;padding:6px 26px}
  .r-nav li{padding:15px 0;border-bottom:1px solid var(--line)}
  .r-nav li:last-child{border-bottom:none}
  .r-nav a{font-size:14px}
  .r-nav a::after{display:none}
  .r-nav-cart{display:block}
  .r-artist .wrap,.r-trust .wrap,.r-footer .cols{grid-template-columns:1fr}
  .r-grid{grid-template-columns:repeat(2,1fr)}
  .sec{padding:72px 0}
  .r-hero{height:58vh;min-height:380px;margin:10px 10px 0}
  .r-hero h1{font-size:clamp(34px,8vw,52px)}
  .r-hero .ov{padding-left:7%;padding-right:6%}
  .r-topbar .wrap{flex-direction:column;height:auto;gap:4px;padding:8px 0;text-align:center}
  .r-topbar{font-size:10px;letter-spacing:1.2px}
  .r-langs{margin:0}
  .r-langs .glang{margin:0 5px}
  .woocommerce nav.woocommerce-pagination ul{gap:6px}
  .woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{min-width:38px;height:38px;line-height:36px;font-size:13px}
}

/* ===================== WOOCOMMERCE ===================== */
.woocommerce .r-page,.woocommerce-page .r-page{padding-top:50px}
.woocommerce-products-header{text-align:center;padding:20px 0 10px}
.woocommerce-products-header__title,.woocommerce .page-title,.r-page .entry-title{font-family:'Playfair Display',serif!important;font-weight:400!important;font-size:clamp(32px,4vw,52px)!important;text-align:center}
.term-description,.woocommerce-products-header__title+*{text-align:center}
.woocommerce-breadcrumb{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin:0 0 34px;text-align:center}
.woocommerce .woocommerce-result-count{color:var(--muted);font-size:13px;letter-spacing:.5px}
.woocommerce .woocommerce-ordering select{border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-family:'Jost';font-size:13px;background:#fff}
.r-filters{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:0 0 38px}
.r-filters .chip{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);padding:9px 22px;border:1px solid var(--line);border-radius:30px;transition:.25s}
.r-filters .chip:hover,.r-filters .chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}

/* shop grid */
.woocommerce ul.products{display:grid!important;grid-template-columns:repeat(3,1fr);gap:24px 28px;margin:30px 0 0!important;padding:0;list-style:none}
.woocommerce ul.products::before,.woocommerce ul.products::after{content:none!important;display:none!important}
.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{width:auto!important;float:none!important;margin:0!important;text-align:left;padding:0}
.woocommerce ul.products li.product a img{border-radius:18px;margin:0 0 16px;aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform 1s ease}
.woocommerce ul.products li.product a:hover img{transform:scale(1.05)}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:'Playfair Display',serif!important;font-style:italic;font-size:23px!important;font-weight:400!important;padding:0 0 4px!important;color:var(--ink)}
.woocommerce ul.products li.product .price{color:var(--ink)!important;font-size:14px;font-weight:300;letter-spacing:.5px}
.woocommerce ul.products li.product .price del{color:var(--muted)}
.woocommerce ul.products li.product .price ins{text-decoration:none}
.woocommerce ul.products li.product .button{margin-top:10px}
.woocommerce span.onsale{background:var(--accent);border-radius:30px;min-height:auto;min-width:auto;padding:6px 14px;font-size:11px;letter-spacing:1px}

/* buttons */
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit,.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce input.button.alt{
  background:var(--ink)!important;color:#fff!important;border-radius:40px!important;padding:14px 32px!important;font-size:12px!important;letter-spacing:2px!important;text-transform:uppercase!important;font-weight:400!important;transition:.3s!important;border:none!important}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover,.woocommerce #respond input#submit:hover{background:var(--accent)!important;color:#fff!important}

/* single product */
.woocommerce div.product{padding-top:10px}
.woocommerce div.product div.images{margin-bottom:30px}
.woocommerce div.product div.images img{border-radius:24px}
.woocommerce div.product div.summary{padding-left:10px}
.rp-uniq{display:inline-block;color:var(--accent);font-size:11px;letter-spacing:3px;text-transform:uppercase;margin-bottom:6px}
.woocommerce div.product .rp-summary h1.product_title{margin:6px 0 2px;line-height:1.05}
.rp-by{font-style:italic;font-family:'Playfair Display',serif;font-size:21px;color:var(--muted);margin-bottom:20px}
.woocommerce div.product .rp-summary p.price{font-size:24px;margin:0 0 6px}
.rp-specs{border-top:1px solid var(--line);margin:18px 0 26px}
.rp-specs>div{display:flex;justify-content:space-between;padding:13px 2px;border-bottom:1px solid var(--line);font-size:14px;gap:20px}
.rp-specs span:first-child{color:var(--muted);letter-spacing:.5px}
.rp-specs span:last-child{text-align:right}
.rp-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.rp-actions form.cart{margin:0;flex:1 1 200px}
.rp-actions .quantity{display:none}
.rp-actions form.cart .single_add_to_cart_button{width:100%}
.rp-info{flex:1 1 200px;text-align:center;display:inline-flex;align-items:center;justify-content:center}
.rp-ship{font-size:13px;color:var(--muted);display:flex;gap:6px;align-items:flex-start;margin-bottom:18px}
.rp-ship strong{color:var(--ink);font-weight:400}
.rp-short{color:#4a4a47;font-size:15px;border-top:1px solid var(--line);padding-top:18px}
/* descripciÃ³ neta de producte */
.woocommerce div.product .rp-desc-section{clear:both;border-top:1px solid var(--line);margin-top:60px;padding-top:54px}
.rp-desc-inner{max-width:760px;margin:0 auto;text-align:center}
.rp-desc-inner .label{display:block;margin-bottom:16px}
.rp-desc-inner p{color:#4a4a47;font-size:16px;line-height:1.8;margin-bottom:14px}
.woocommerce div.product .woocommerce-tabs{display:none}
/* paginaciÃ³ de la botiga */
.woocommerce nav.woocommerce-pagination{margin:64px 0 0;text-align:center;border:none}
.woocommerce nav.woocommerce-pagination ul{border:none;display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:0;padding:0}
.woocommerce nav.woocommerce-pagination ul li{border:none;margin:0;overflow:visible}
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{border:1px solid var(--line)!important;border-radius:50%;min-width:46px;height:46px;line-height:44px;padding:0;font-size:14px;color:var(--ink);background:#fff;transition:.25s}
.woocommerce nav.woocommerce-pagination ul li a:hover,.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important}
.woocommerce div.product .product_title{font-family:'Playfair Display',serif;font-size:clamp(34px,4vw,54px);font-weight:400;line-height:1.05}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--ink)!important;font-size:24px;font-weight:300}
.woocommerce div.product .woocommerce-product-details__short-description{color:#4a4a47;margin:18px 0}
.woocommerce .product .woocommerce-tabs{grid-column:1 / -1;margin-top:30px}
.woocommerce div.product .woocommerce-tabs ul.tabs li{border-radius:30px 30px 0 0}
.woocommerce table.shop_attributes{border:1px solid var(--line);border-radius:16px;overflow:hidden}
.woocommerce .related.products,.woocommerce .upsells.products{grid-column:1 / -1;margin-top:40px}
.woocommerce .related.products>h2,.woocommerce .upsells.products>h2{font-family:'Playfair Display',serif;font-weight:400;font-size:32px;text-align:center;margin-bottom:30px}

/* cart / checkout / account */
.woocommerce table.shop_table{border:1px solid var(--line);border-radius:18px;border-collapse:separate;overflow:hidden}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce .input-text,.select2-container--default .select2-selection--single{border:1px solid var(--line)!important;border-radius:12px!important;padding:12px 14px!important;font-family:'Jost'!important}
.woocommerce #payment,.woocommerce .cart_totals,.woocommerce-checkout #payment{border-radius:18px}
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-top-color:var(--accent)!important;border-radius:12px}

@media(max-width:860px){
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr)}
  .woocommerce div.product{grid-template-columns:1fr;gap:26px}
}

/* ===== Google Translate (CA/ES/EN) â€” amaga la barra ===== */
.goog-te-banner-frame.skiptranslate,iframe.skiptranslate,.goog-te-gadget-icon,#goog-gt-tt,.goog-te-balloon-frame{display:none!important}
body{top:0!important;position:static!important}
.goog-text-highlight{background:none!important;box-shadow:none!important;color:inherit!important}
#google_translate_element{position:absolute!important;left:-9999px!important;top:-9999px!important;height:0;overflow:hidden}
.r-langs .glang{cursor:pointer;margin-left:10px;transition:color .2s}
.r-langs .glang:hover,.r-langs .glang.on{color:var(--accent)}

/* ===== Scroll reveal (aparició suau en baixar) ===== */
.r-hero .ov,.sec-head,.r-grid .r-piece,.woocommerce ul.products li.product,.r-artist .ph,.r-artist .txt,.r-trust .wrap>div,.rp-desc-section,.r-filters{transition:opacity .85s cubic-bezier(.22,.7,.2,1),transform .85s cubic-bezier(.22,.7,.2,1)}
html.reveal-on .r-hero .ov,html.reveal-on .sec-head,html.reveal-on .r-grid .r-piece,html.reveal-on .woocommerce ul.products li.product,html.reveal-on .r-artist .ph,html.reveal-on .r-artist .txt,html.reveal-on .r-trust .wrap>div,html.reveal-on .rp-desc-section,html.reveal-on .r-filters{opacity:0;transform:translateY(28px)}
.r-reveal-in{opacity:1!important;transform:none!important}

/* ===== Botons flotants mòbil: tornar amunt + cistella ===== */
.r-fab{display:none}
@media(max-width:860px){
  .r-fab{position:fixed;z-index:60;width:50px;height:50px;border-radius:50%;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(0,0,0,.28);border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}
  .r-totop{display:flex;right:16px;bottom:16px;background:var(--ink);color:#fff;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .3s,transform .3s,visibility .3s}
  .r-totop.show{opacity:1;visibility:visible;transform:none}
  .r-fabcart{left:16px;bottom:16px;background:var(--accent);color:#fff;text-decoration:none}
  body.woocommerce .r-fabcart,body.woocommerce-page .r-fabcart{display:flex}
  .r-fabcart-n{position:absolute;top:-3px;right:-3px;background:var(--ink);color:#fff;font-size:11px;font-weight:500;min-width:19px;height:19px;line-height:19px;border-radius:10px;text-align:center;padding:0 4px;box-shadow:0 1px 4px rgba(0,0,0,.35)}
}

/* ===== Galeria d'ambient (L'artista) + band de context (home) ===== */
.r-amb-grid{column-count:3;column-gap:24px}
.r-amb-grid figure{break-inside:avoid;margin:0 0 24px}
.r-amb-grid img{width:100%;border-radius:16px;display:block}
.r-amb-grid figcaption{font-family:'Playfair Display',Georgia,serif;font-style:italic;font-size:15px;color:var(--muted);line-height:1.5;margin-top:11px}
@media(max-width:980px){.r-amb-grid{column-count:2}}
@media(max-width:600px){.r-amb-grid{column-count:1}}

.r-context-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.r-context-grid figure{margin:0}
.r-context-grid img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:18px;display:block}
.r-context-grid figcaption{font-family:'Playfair Display',Georgia,serif;font-style:italic;font-size:15px;color:var(--muted);margin-top:12px;text-align:center}
@media(max-width:860px){.r-context-grid{grid-template-columns:1fr;gap:20px}.r-context-grid img{aspect-ratio:16/10}}

/* reveal per a les noves galeries */
.r-context-grid figure,.r-amb-grid figure{transition:opacity .85s cubic-bezier(.22,.7,.2,1),transform .85s cubic-bezier(.22,.7,.2,1)}
html.reveal-on .r-context-grid figure,html.reveal-on .r-amb-grid figure{opacity:0;transform:translateY(28px)}

/* ===== Banner discret arracades / joies (botiga) ===== */
.r-toast{position:fixed;z-index:120;right:24px;bottom:24px;width:360px;max-width:calc(100vw - 32px);background:var(--bg);border:1px solid var(--line);border-radius:18px;box-shadow:0 16px 50px rgba(0,0,0,.22);padding:18px 20px;opacity:0;visibility:hidden;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease,visibility .4s}
.r-toast.show{opacity:1;visibility:visible;transform:none}
.r-toast-in{display:flex;gap:14px;align-items:flex-start}
.r-toast-emblem{width:46px;height:46px;border-radius:50%;flex:0 0 auto;display:block}
.r-toast-tx strong{font-family:'Playfair Display',Georgia,serif;font-weight:400;font-size:18px;color:var(--ink);display:block;margin-bottom:5px}
.r-toast-tx p{font-size:13.5px;color:#4a4a47;line-height:1.5;margin-bottom:10px}
.r-toast-ig{font-size:11.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--accent);font-weight:500}
.r-toast-ig:hover{color:var(--ink)}
.r-toast-x{position:absolute;top:8px;right:11px;background:none;border:0;font-size:22px;line-height:1;color:var(--muted);cursor:pointer;padding:2px}
.r-toast-x:hover{color:var(--ink)}
@media(max-width:860px){.r-toast{left:14px;right:14px;bottom:84px;width:auto;max-width:none}}

/* ===== Exposició destacada (Exposicions) ===== */
.rx-feature{display:grid;grid-template-columns:auto 1fr;gap:50px;align-items:center;margin:10px 0 60px;padding-bottom:58px;border-bottom:1px solid var(--line)}
.rx-feature-imgs{display:flex;gap:14px;flex:0 0 auto}
.rx-feature-imgs img{width:172px;border-radius:14px;box-shadow:0 16px 40px rgba(0,0,0,.16);display:block}
.rx-feature-tx h2{font-size:clamp(34px,5vw,54px);margin:12px 0 6px;line-height:1}
.rx-feature-meta{font-size:15px;color:var(--ink);margin-bottom:4px}
.rx-feature-dates{font-size:12.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.rx-feature-tx>p:last-child{color:#4a4a47;max-width:50ch;line-height:1.7}
@media(max-width:860px){
  .rx-feature{grid-template-columns:1fr;gap:26px;text-align:center}
  .rx-feature-imgs{justify-content:center}
  .rx-feature-imgs img{width:42%;max-width:175px}
  .rx-feature-tx>p:last-child{margin:0 auto}
}
