/*
Theme Name: RKIA AIT BLAL — Haute Couture Marocaine
Theme URI: https://rkiaaitblal.com
Author: RKIA AIT BLAL Maison
Author URI: https://rkiaaitblal.com
Description: Thème WooCommerce de haute couture marocaine — « Dior meets Moroccan Royal Heritage ». Caftans et takchitas d'exception, atmosphère de palais, broderie d'or. Compatible WooCommerce (boutique, fiche produit, panier, variations).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: rkia
WC requires at least: 7.0
WC tested up to: 8.7
Tags: e-commerce, fashion, luxury, custom-colors, custom-menu, featured-images, translation-ready
*/

/* =========================================================
   RKIA AIT BLAL — Design system
   ========================================================= */
:root{
  --ivory:#F7F3EC;
  --champagne:#C8A46B;
  --beige:#E2D8C9;
  --black:#15110B;
  --soft-gold:#B0863F;
  --deep-gold:#8a6326;
  --ink:#1c1813;
  --muted:#7a7064;
  --zellige:#1d4f55;
  --henna:#7a3a22;
  --line:rgba(21,17,11,.14);
  --gold-grad:linear-gradient(135deg,#E7CF95 0%,#C8A46B 42%,#A9803E 100%);
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Montserrat', system-ui, sans-serif;
  --ease:cubic-bezier(.19,1,.22,1);
  --gutter:clamp(20px,6vw,130px);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--ivory);color:var(--ink);line-height:1.62;font-weight:300;letter-spacing:.02em;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.05;letter-spacing:.01em}
.eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.46em;text-transform:uppercase;font-weight:500;color:var(--soft-gold)}
.arch{border-radius:48% 48% 7px 7px / 27% 27% 0 0;}

/* flourish ornament */
.flourish{display:flex;align-items:center;justify-content:center;gap:18px;margin:0 auto 8px}
.flourish::before,.flourish::after{content:"";width:clamp(40px,9vw,96px);height:1px;background:linear-gradient(90deg,transparent,var(--champagne))}
.flourish::after{background:linear-gradient(90deg,var(--champagne),transparent)}
.flourish svg{width:24px;height:24px;display:block;flex:none}
.flourish--light::before{background:linear-gradient(90deg,transparent,rgba(200,164,107,.85))}
.flourish--light::after{background:linear-gradient(90deg,rgba(200,164,107,.85),transparent)}

/* buttons */
.btn,.rkia-btn{display:inline-block;font-family:var(--sans);font-size:11px;letter-spacing:.32em;text-transform:uppercase;font-weight:500;padding:18px 40px;border:1px solid var(--black);color:var(--black);background:transparent;cursor:pointer;position:relative;overflow:hidden;transition:color .6s var(--ease);z-index:1}
.btn::after,.rkia-btn::after{content:"";position:absolute;inset:0;background:var(--black);transform:translateY(101%);transition:transform .6s var(--ease);z-index:-1}
.btn:hover,.rkia-btn:hover{color:var(--ivory)}
.btn:hover::after,.rkia-btn:hover::after{transform:translateY(0)}
.btn--light{border-color:rgba(255,255,255,.7);color:#fff}
.btn--light::after{background:var(--ivory)}
.btn--light:hover{color:var(--black)}
.btn--solid{background:var(--black);color:var(--ivory)}
.btn--solid::after{background:var(--soft-gold)}
.btn--solid:hover{color:#fff}

/* reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}.reveal.d4{transition-delay:.48s}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:26px var(--gutter);transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease)}
.site-header.scrolled,.site-header.is-solid{background:rgba(247,243,236,.94);backdrop-filter:blur(10px);padding:16px var(--gutter);box-shadow:0 1px 0 var(--line)}
.brand{font-family:var(--serif);font-size:clamp(20px,2.4vw,28px);letter-spacing:.34em;color:#fff;font-weight:500;transition:color .5s var(--ease);padding-left:.34em}
.scrolled .brand,.is-solid .brand{color:var(--black)}
.brand img{max-height:42px;width:auto;display:inline-block}
.nav{display:flex;gap:clamp(22px,2.4vw,46px);align-items:center;list-style:none}
.nav a{font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;color:rgba(255,255,255,.86);position:relative;padding:4px 0;transition:color .4s var(--ease)}
.scrolled .nav a,.is-solid .nav a{color:var(--ink)}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--champagne);transition:width .45s var(--ease)}
.nav a:hover{color:var(--champagne)}
.nav a:hover::after{width:100%}
.nav .current-menu-item>a::after,.nav .current_page_item>a::after{width:100%}
.nav-tools{display:flex;gap:20px;align-items:center}
.nav-tools a{position:relative;display:flex}
.nav-tools svg{width:18px;height:18px;stroke:#fff;transition:stroke .5s var(--ease)}
.scrolled .nav-tools svg,.is-solid .nav-tools svg{stroke:var(--black)}
.cart-count{position:absolute;top:-8px;right:-10px;background:var(--soft-gold);color:#fff;font-size:9px;line-height:1;min-width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sans);letter-spacing:0;padding:0 2px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px}
.burger span{width:26px;height:1.5px;background:#fff;transition:background .5s var(--ease)}
.scrolled .burger span,.is-solid .burger span{background:var(--black)}

.drawer{position:fixed;inset:0;background:var(--ivory);z-index:1100;transform:translateX(100%);transition:transform .6s var(--ease);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:30px}
.drawer.open{transform:none}
.drawer a{font-family:var(--serif);font-size:30px;letter-spacing:.04em;color:var(--black)}
.drawer .close{position:absolute;top:28px;right:28px;font-size:30px;background:none;border:none;cursor:pointer;font-family:var(--serif)}
.drawer .nav{flex-direction:column;gap:30px;align-items:center}
.drawer .nav a{font-family:var(--serif);font-size:30px;color:var(--black);letter-spacing:.04em}
.drawer .nav a::after{display:none}

/* inner page main spacing (non-home) */
.site-main{min-height:60vh}
.is-inner .site-main{padding-top:clamp(96px,12vh,128px)}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-position:center 30%;background-size:cover;background-repeat:no-repeat;transform:scale(1.08);animation:heroZoom 16s var(--ease) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__overlay{position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 18%,rgba(21,17,11,.18),transparent 60%),linear-gradient(180deg,rgba(21,17,11,.62) 0%,rgba(21,17,11,.30) 42%,rgba(21,17,11,.74) 100%)}
.hero__frame{position:absolute;inset:clamp(16px,3vw,42px);border:1px solid rgba(200,164,107,.42);z-index:2;pointer-events:none}
.hero__content{position:relative;z-index:3;padding:0 24px;max-width:960px}
.hero__eyebrow{display:block;color:var(--champagne);font-size:12px;letter-spacing:.52em;text-transform:uppercase;margin-bottom:28px;font-weight:500;opacity:0;animation:fadeUp 1.2s var(--ease) .4s forwards}
.hero h1{font-size:clamp(50px,9.4vw,140px);font-weight:300;letter-spacing:.06em;line-height:.94;opacity:0;animation:fadeUp 1.4s var(--ease) .7s forwards}
.hero__sub{font-family:var(--serif);font-style:italic;font-size:clamp(19px,2.6vw,33px);letter-spacing:.1em;margin-top:20px;color:rgba(255,255,255,.94);opacity:0;animation:fadeUp 1.4s var(--ease) 1s forwards}
.hero__text{max-width:580px;margin:26px auto 0;font-size:14px;font-weight:300;color:rgba(255,255,255,.82);letter-spacing:.06em;opacity:0;animation:fadeUp 1.4s var(--ease) 1.25s forwards}
.hero__cta{margin-top:48px;display:flex;gap:18px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp 1.4s var(--ease) 1.5s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:none}}
.hero__scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.75);display:flex;flex-direction:column;align-items:center;gap:12px;opacity:0;animation:fadeUp 1.4s var(--ease) 1.9s forwards}
.hero__scroll::after{content:"";width:1px;height:46px;background:rgba(255,255,255,.5);animation:scrollLine 2.2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* =========================================================
   SECTION SHELL
   ========================================================= */
section{position:relative}
.section{padding:clamp(88px,13vh,180px) var(--gutter)}
.section-head{text-align:center;max-width:760px;margin:0 auto clamp(52px,7vh,92px)}
.section-head h2{font-size:clamp(36px,5.6vw,78px);margin:14px 0;letter-spacing:.02em}
.section-head p{color:var(--muted);font-size:14px;max-width:540px;margin:14px auto 0}

/* DESIGNER */
.designer{display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(40px,6vw,104px);align-items:center}
.designer__img{position:relative;overflow:hidden}
.designer__img img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.4s var(--ease)}
.designer__img:hover img{transform:scale(1.05)}
.designer__img::before{content:"";position:absolute;inset:14px;border:1px solid rgba(200,164,107,.55);z-index:2;pointer-events:none;border-radius:46% 46% 4px 4px / 24% 24% 0 0}
.designer__sig{font-family:var(--serif);font-style:italic;font-size:32px;color:var(--soft-gold);margin-top:8px}
.designer h2{font-size:clamp(34px,4.6vw,64px);margin:20px 0 26px;line-height:1.04}
.designer p{color:var(--muted);font-size:15px;margin-bottom:20px;max-width:540px}
.designer .btn{margin-top:14px}

/* COLLECTIONS (editorial cards / featured products grid) */
.collections-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.6vw,44px)}
.collection-card{position:relative;overflow:hidden;cursor:pointer;background:#000;border-radius:42% 42% 6px 6px / 16% 16% 0 0}
.collection-card img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.6s var(--ease),opacity 1.2s var(--ease)}
.collection-card:hover img{transform:scale(1.07);opacity:.78}
.collection-card__body{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(26px,3vw,50px);color:#fff;background:linear-gradient(180deg,transparent 42%,rgba(21,17,11,.78) 100%)}
.collection-card__num{font-size:11px;letter-spacing:.34em;color:var(--champagne);margin-bottom:10px}
.collection-card h3{font-size:clamp(26px,3vw,44px);font-weight:300;letter-spacing:.04em}
.collection-card .price{font-family:var(--serif);font-size:20px;color:var(--champagne);margin-top:8px;display:block}
.collection-card__link{margin-top:18px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--champagne);opacity:0;transform:translateY(10px);transition:opacity .6s var(--ease) .1s,transform .6s var(--ease) .1s}
.collection-card:hover .collection-card__link{opacity:1;transform:none}

/* ATELIER */
.atelier{background:var(--black);color:var(--ivory);position:relative;overflow:hidden}
.atelier::before,.newsletter::before,.atelier-story::before{content:"";position:absolute;inset:0;opacity:.10;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Cg fill='none' stroke='%23C8A46B' stroke-width='1'%3E%3Crect x='16' y='16' width='32' height='32'/%3E%3Crect x='16' y='16' width='32' height='32' transform='rotate(45 32 32)'/%3E%3C/g%3E%3C/svg%3E");background-size:64px 64px}
.atelier-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,96px);align-items:center;position:relative;z-index:1}
.atelier__img{position:relative;overflow:hidden}
.atelier__img img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.6s var(--ease)}
.atelier__img:hover img{transform:scale(1.06)}
.atelier__img::before{content:"";position:absolute;inset:14px;border:1px solid rgba(200,164,107,.5);z-index:2;pointer-events:none;border-radius:46% 46% 4px 4px / 24% 24% 0 0}
.atelier h2{font-size:clamp(36px,4.8vw,68px);margin:18px 0 30px;color:var(--ivory)}
.atelier__intro{color:rgba(247,243,236,.72);font-size:15px;margin-bottom:40px;max-width:500px}
.timeline{list-style:none}
.timeline li{display:flex;align-items:baseline;gap:24px;padding:24px 0;border-top:1px solid rgba(247,243,236,.16);transition:padding-left .5s var(--ease)}
.timeline li:last-child{border-bottom:1px solid rgba(247,243,236,.16)}
.timeline li:hover{padding-left:14px}
.timeline .num{font-family:var(--serif);font-size:27px;color:var(--champagne);min-width:48px}
.timeline .step h4{font-size:23px;color:var(--ivory);font-weight:400;letter-spacing:.04em}
.timeline .step span{font-size:12px;color:rgba(247,243,236,.58);letter-spacing:.04em}

/* MASONRY */
.masonry{columns:3;column-gap:clamp(16px,1.8vw,30px)}
.masonry figure{break-inside:avoid;margin:0 0 clamp(16px,1.8vw,30px);position:relative;overflow:hidden}
.masonry img{width:100%;transition:transform 1.5s var(--ease),filter 1s var(--ease)}
.masonry figure:hover img{transform:scale(1.05)}
.masonry figcaption{position:absolute;left:0;bottom:0;width:100%;padding:22px;color:#fff;font-family:var(--serif);font-style:italic;font-size:20px;letter-spacing:.04em;background:linear-gradient(180deg,transparent,rgba(21,17,11,.7));opacity:0;transform:translateY(14px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.masonry figure:hover figcaption{opacity:1;transform:none}

/* PRESS */
.press{background:var(--beige)}
.press-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,36px)}
.press-card{background:var(--ivory);overflow:hidden;display:flex;flex-direction:column}
.press-card__img{overflow:hidden}
.press-card img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.4s var(--ease)}
.press-card:hover img{transform:scale(1.07)}
.press-card__body{padding:30px 26px 36px}
.press-card .tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--soft-gold)}
.press-card h3{font-size:25px;margin:14px 0 12px;font-weight:400;line-height:1.15}
.press-card p{font-size:13px;color:var(--muted)}
.press-card .date{font-size:11px;letter-spacing:.18em;color:var(--muted);margin-top:18px;text-transform:uppercase}

/* COUTURE BANNER */
.couture-banner{position:relative;min-height:84vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.couture-banner__bg{position:absolute;inset:0;background-position:center 35%;background-size:cover;background-repeat:no-repeat}
.couture-banner__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,17,11,.55),rgba(21,17,11,.62))}
.couture-banner__frame{position:absolute;inset:clamp(16px,3vw,46px);border:1px solid rgba(200,164,107,.4);z-index:1;pointer-events:none}
.couture-banner__content{position:relative;z-index:2;max-width:780px;padding:0 24px}
.couture-banner h2{font-size:clamp(38px,6.2vw,92px);font-weight:300;letter-spacing:.04em;line-height:1.02}
.couture-banner p{margin:26px auto 38px;max-width:540px;color:rgba(255,255,255,.86);font-size:15px}
@media(min-width:861px){.couture-banner__bg{background-attachment:fixed}}

/* INSTAGRAM */
.insta-head{text-align:center;margin-bottom:50px}
.insta-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.insta-grid a{position:relative;overflow:hidden;display:block;aspect-ratio:1}
.insta-grid img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.insta-grid a::after{content:"@";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(21,17,11,.5);color:#fff;opacity:0;transition:opacity .5s var(--ease);font-size:24px;font-family:var(--serif);font-style:italic}
.insta-grid a:hover img{transform:scale(1.12)}
.insta-grid a:hover::after{opacity:1}

/* NEWSLETTER */
.newsletter{background:var(--black);color:var(--ivory);text-align:center;position:relative;overflow:hidden}
.newsletter::before{opacity:.08}
.newsletter>div{position:relative;z-index:1}
.newsletter h2{font-size:clamp(34px,4.8vw,64px);color:var(--ivory);margin:16px 0 18px}
.newsletter p{color:rgba(247,243,236,.66);max-width:480px;margin:0 auto 38px;font-size:14px}
.newsletter form{display:flex;max-width:520px;margin:0 auto;gap:0;border-bottom:1px solid rgba(247,243,236,.35)}
.newsletter input{flex:1;background:transparent;border:none;color:var(--ivory);padding:16px 4px;font-family:var(--sans);font-size:13px;letter-spacing:.08em}
.newsletter input::placeholder{color:rgba(247,243,236,.5)}
.newsletter input:focus{outline:none}
.newsletter button{background:none;border:none;color:var(--champagne);cursor:pointer;font-size:11px;letter-spacing:.3em;text-transform:uppercase;padding:0 8px;transition:color .4s var(--ease)}
.newsletter button:hover{color:#fff}

/* FOOTER */
.footer{background:#100c07;color:rgba(247,243,236,.7);padding:clamp(64px,9vh,120px) var(--gutter) 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:clamp(30px,4vw,70px);margin-bottom:60px}
.footer-brand .brand{color:var(--ivory);font-size:26px;display:inline-block;margin-bottom:20px}
.footer-brand p{font-size:13px;max-width:320px;color:rgba(247,243,236,.55)}
.footer h4{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--champagne);margin-bottom:24px;font-family:var(--sans)}
.footer ul{list-style:none}
.footer ul li{margin-bottom:13px}
.footer ul a{font-size:13px;color:rgba(247,243,236,.62);transition:color .4s var(--ease)}
.footer ul a:hover{color:var(--champagne)}
.footer-social{display:flex;gap:18px;margin-top:8px}
.footer-social a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(247,243,236,.62);transition:color .4s}
.footer-social a:hover{color:var(--champagne)}
.footer-bottom{border-top:1px solid rgba(247,243,236,.12);padding-top:30px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:11px;letter-spacing:.14em;color:rgba(247,243,236,.4);text-transform:uppercase}

/* =========================================================
   WOOCOMMERCE
   ========================================================= */
.woo-page{padding:0 var(--gutter) clamp(70px,10vh,130px)}
.woo-head{text-align:center;max-width:760px;margin:0 auto clamp(40px,6vh,72px)}
.woo-head h1,.woo-head .page-title{font-size:clamp(34px,5vw,68px);margin:14px 0;font-weight:300}
.woocommerce-breadcrumb{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:36px}
.woocommerce-breadcrumb a:hover{color:var(--champagne)}
.woocommerce-result-count{font-size:12px;letter-spacing:.1em;color:var(--muted)}
.woocommerce-ordering select{font-family:var(--sans);font-size:12px;padding:10px 14px;border:1px solid var(--line);background:var(--ivory)}

/* shop / loop grid */
.woocommerce ul.products{display:grid !important;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,44px);margin:0;padding:0;list-style:none}
.woocommerce ul.products::before,.woocommerce ul.products::after{display:none}
.woocommerce ul.products li.product{width:auto !important;margin:0 !important;float:none !important;text-align:left}
.woocommerce ul.products li.product a img{margin:0 0 18px;border-radius:42% 42% 6px 6px / 14% 14% 0 0;aspect-ratio:4/5;object-fit:cover;width:100%;transition:transform 1.4s var(--ease)}
.woocommerce ul.products li.product:hover a img{transform:scale(1.04)}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--serif);font-size:24px;font-weight:400;padding:0;margin:4px 0 6px;color:var(--ink)}
.woocommerce ul.products li.product .price{font-family:var(--serif);font-size:19px;color:var(--ink)}
.woocommerce ul.products li.product .price del{color:var(--muted);opacity:.6;margin-right:8px}
.woocommerce ul.products li.product .price ins{text-decoration:none;color:var(--henna)}
.woocommerce ul.products li.product .button{margin-top:14px}
.woocommerce ul.products li.product .onsale,.woocommerce span.onsale{position:absolute;top:14px;left:14px;background:var(--black);color:var(--champagne);min-height:auto;min-width:auto;line-height:1;padding:8px 14px;border-radius:0;font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;margin:0}
.woocommerce ul.products li.product{position:relative}
.star-rating{color:var(--soft-gold);font-size:.9em;margin:6px 0}

/* buttons (add to cart, etc.) */
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit,.woocommerce a.button.alt,.woocommerce button.button.alt{
  font-family:var(--sans);font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  padding:16px 32px;border:1px solid var(--black);color:var(--ivory);background:var(--black);
  border-radius:0;position:relative;overflow:hidden;transition:color .5s var(--ease),background .5s var(--ease);cursor:pointer
}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce #respond input#submit:hover,.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover{background:var(--soft-gold);border-color:var(--soft-gold);color:#fff}
.woocommerce .button.loading::after{font-family:'WooCommerce'}

/* single product */
.single-product .site-main{padding-top:clamp(96px,12vh,128px)}
.woocommerce div.product{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(36px,5vw,86px);align-items:start}
.woocommerce div.product .woocommerce-product-gallery{width:100% !important;margin:0;position:sticky;top:96px}
.woocommerce div.product .woocommerce-product-gallery__image img{border-radius:40% 40% 6px 6px / 12% 12% 0 0}
.woocommerce div.product .summary{margin:0;padding-top:4px}
.woocommerce div.product .product_title{font-size:clamp(38px,4.8vw,64px);font-weight:300;line-height:1.02;margin-bottom:16px}
.woocommerce div.product p.price,.woocommerce div.product span.price{font-family:var(--serif);font-size:30px;color:var(--ink);margin-bottom:18px}
.woocommerce div.product p.price ins{text-decoration:none;color:var(--henna)}
.woocommerce div.product p.price del{opacity:.55;font-size:.7em;margin-right:10px}
.woocommerce div.product .woocommerce-product-rating{margin-bottom:22px}
.woocommerce div.product .woocommerce-product-details__short-description{font-size:15px;color:var(--muted);margin-bottom:28px;max-width:500px}
.woocommerce .quantity .qty{height:50px;border:1px solid var(--line);background:transparent;width:74px;text-align:center;font-family:var(--sans)}
.woocommerce div.product form.cart{margin:24px 0}
.woocommerce div.product form.cart .button{vertical-align:middle;height:50px;line-height:1}
.woocommerce table.variations{margin:10px 0 24px}
.woocommerce table.variations td,.woocommerce table.variations th{padding:8px 0;vertical-align:middle}
.woocommerce table.variations label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);font-weight:500}
.woocommerce table.variations select{font-family:var(--sans);padding:12px 14px;border:1px solid var(--line);background:var(--ivory);min-width:180px}
.woocommerce .single_variation .price{font-family:var(--serif);font-size:26px;color:var(--ink)}
.product_meta{font-size:12px;color:var(--muted);letter-spacing:.04em;line-height:2;margin-top:22px}
.product_meta a:hover{color:var(--champagne)}
/* tabs */
.woocommerce div.product .woocommerce-tabs{grid-column:1 / -1;margin-top:clamp(40px,6vh,80px)}
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;border-bottom:1px solid var(--line);display:flex;gap:34px;flex-wrap:wrap}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:none;border:none;border-radius:0;padding:0;margin:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{font-family:var(--serif);font-size:22px;color:var(--muted);padding:14px 0;display:inline-block}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--ink);border-bottom:1px solid var(--champagne)}
.woocommerce div.product .woocommerce-tabs .panel{padding-top:26px;font-size:14px;color:var(--muted);max-width:760px}
.woocommerce div.product .woocommerce-tabs .panel h2{display:none}
/* upsells / related */
.woocommerce .related,.woocommerce .upsells{grid-column:1 / -1;margin-top:clamp(50px,8vh,110px)}
.woocommerce .related>h2,.woocommerce .upsells>h2,.woocommerce .cross-sells>h2{font-family:var(--serif);font-size:clamp(30px,4vw,52px);font-weight:300;text-align:center;margin-bottom:clamp(36px,5vh,64px)}

/* notices */
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-top-color:var(--champagne);background:#fff;font-size:13px}
.woocommerce-message::before,.woocommerce-info::before{color:var(--champagne)}

/* cart & checkout */
.woocommerce table.shop_table{border-radius:0}
.woocommerce-cart table.cart img{width:90px;border-radius:30% 30% 4px 4px / 10% 10% 0 0}
.woocommerce .cart-collaterals .cart_totals h2,.woocommerce-checkout h3{font-family:var(--serif);font-weight:400}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.select2-container .select2-selection{border:1px solid var(--line);border-radius:0;padding:12px 14px;font-family:var(--sans)}
.woocommerce-checkout #payment{background:var(--beige);border-radius:0}

/* pagination */
.woocommerce nav.woocommerce-pagination ul{border:none;margin-top:50px}
.woocommerce nav.woocommerce-pagination ul li{border:none}
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{border:1px solid var(--line);padding:10px 16px;font-size:12px}
.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--black);color:var(--ivory);border-color:var(--black)}

/* widgets / sidebar off */
.woocommerce-page .content-area{width:100%}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1024px){
  .press-grid{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:2}
  .insta-grid{grid-template-columns:repeat(4,1fr)}
  .woocommerce ul.products{grid-template-columns:repeat(3,1fr)}
  .woocommerce div.product{grid-template-columns:1fr}
  .woocommerce div.product .woocommerce-product-gallery{position:static}
}
@media(max-width:860px){
  .nav,.nav-tools{display:none}
  .burger{display:flex}
  .designer,.atelier-wrap{grid-template-columns:1fr;gap:40px}
  .atelier__img{order:-1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .collections-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .hero__cta{flex-direction:column;align-items:center}
  .btn{width:100%;max-width:300px;text-align:center}
  .woocommerce ul.products{grid-template-columns:1fr 1fr;gap:16px}
}
