/* === ArtFlower v4.1 - check this line exists === */
/* ============================================================
   ArtFlower Florist — v4 Stylesheet
   Brand: minimal ink-and-cream, editorial botanical
   ============================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --ink:     #2A2320;
  --cream:   #FAF7F2;
  --cream2:  #F2EDE6;
  --blush:   #E8D5D0;
  --gold:    #C9A96E;
  --gold-d:  #A8854A;
  --sage:    #8A9E7C;
  --sage-l:  #E4EDE0;
  --mid:     #9B8B85;
  --light:   #F5F0EB;
  --white:   #FFFFFF;

  --radius:  14px;
  --radius-sm: 8px;
  --shadow:  0 6px 28px rgba(42,35,32,0.08);
  --shadow-md: 0 12px 42px rgba(42,35,32,0.11);
  --shadow-lg: 0 24px 64px rgba(42,35,32,0.13);
  --trans:   all 0.38s cubic-bezier(0.25,0.46,0.45,0.94);
  --max-w:   1200px;

  --serif:   'Playfair Display','Noto Serif SC',Georgia,serif;
  --sans:    'Poppins','Noto Serif SC',sans-serif;
  --header-h: 72px;
}

html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--ink);background:var(--cream);
  line-height:1.8;-webkit-font-smoothing:antialiased;overflow-x:hidden
}
a{color:var(--ink);text-decoration:none;transition:var(--trans)}
a:hover{color:var(--gold)}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
.container{max-width:var(--max-w);margin:0 auto;padding:0 28px}
.section{padding:96px 0;position:relative}

/* ── Section headings ─────────────────────────────────────── */
.section-title{
  font-family:var(--serif);font-size:2.2rem;text-align:center;
  margin-bottom:10px;color:var(--ink);font-weight:700;font-style:italic
}
.section-title::after{
  content:'';display:block;width:36px;height:1.5px;
  background:var(--gold);margin:14px auto 0;border-radius:1px
}
.section-subtitle{
  text-align:center;color:var(--mid);font-size:0.95rem;
  margin-bottom:48px;font-weight:300;max-width:560px;
  margin-left:auto;margin-right:auto;letter-spacing:0.3px
}

/* ── Buttons ──────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;font-family:var(--sans);font-size:0.88rem;
  font-weight:600;border:none;cursor:pointer;transition:var(--trans);
  letter-spacing:1.2px;text-transform:uppercase
}
.btn-primary{
  background:var(--ink);color:var(--cream);
  box-shadow:0 4px 16px rgba(42,35,32,0.18)
}
.btn-primary:hover{background:#3E3330;color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-secondary{
  background:transparent;color:var(--ink);
  border:1.5px solid var(--ink)
}
.btn-secondary:hover{background:var(--ink);color:var(--cream);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--white);box-shadow:0 4px 14px rgba(201,169,110,0.28)}
.btn-gold:hover{background:var(--gold-d);color:var(--white);transform:translateY(-2px)}
.btn-sage{background:var(--sage);color:var(--white)}
.btn-sage:hover{background:#6E8862;color:var(--white);transform:translateY(-2px)}

/* ── Loader ───────────────────────────────────────────────── */
.page-loader{
  position:fixed;inset:0;background:var(--cream);z-index:9999;
  display:flex;align-items:center;justify-content:center;
  transition:opacity 0.5s ease,visibility 0.5s ease
}
.page-loader.hidden{opacity:0;visibility:hidden}
.loader-icon{font-size:2rem;animation:spin 1.6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Header ───────────────────────────────────────────────── */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(250,247,242,0.94);backdrop-filter:blur(18px) saturate(160%);
  border-bottom:1px solid rgba(42,35,32,0.07);transition:var(--trans)
}
.header.scrolled{box-shadow:0 2px 24px rgba(42,35,32,0.06)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 28px;max-width:var(--max-w);margin:0 auto
}

/* Logo: real logo image + brand name */
.nav-logo{display:flex;align-items:center;gap:12px;color:var(--ink);font-family:var(--serif)}
.nav-logo-img{width:44px;height:44px;border-radius:50%;object-fit:cover}
/* legacy fallback: any old-markup logo stays constrained */
.logo-icon{width:44px;height:44px;border-radius:50%;overflow:hidden;display:inline-flex;flex-shrink:0}
.logo-icon img{width:100%;height:100%;object-fit:cover}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.1}
.nav-logo-text .brand-name{font-size:1.1rem;font-weight:700;font-style:italic;letter-spacing:0.3px}
.nav-logo-text .brand-sub{font-size:0.62rem;letter-spacing:4px;text-transform:uppercase;color:var(--mid);font-style:normal}

.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{
  color:var(--ink);font-size:0.82rem;font-weight:500;padding:4px 0;
  font-family:var(--sans);letter-spacing:1px;text-transform:uppercase;
  position:relative
}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;
  background:var(--gold);transition:var(--trans)
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--gold)}
.nav-toggle{
  display:none;background:none;border:none;cursor:pointer;
  padding:6px;color:var(--ink)
}
.nav-right{display:flex;align-items:center;gap:6px;margin-left:8px}
.lang-toggle{display:flex;gap:3px}
.lang-btn{
  padding:3px 8px;border:1px solid rgba(42,35,32,0.2);border-radius:3px;
  background:transparent;color:var(--mid);cursor:pointer;font-size:0.68rem;
  font-weight:600;transition:var(--trans);font-family:var(--sans);letter-spacing:0.8px
}
.lang-btn:hover{border-color:var(--gold);color:var(--gold)}
.lang-btn.active{background:var(--ink);border-color:var(--ink);color:var(--cream)}

/* ── Hero ─────────────────────────────────────────────────── */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:120px 28px 80px;position:relative;overflow:hidden;
  background:var(--cream)
}
/* thin ruled lines background texture */
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(42,35,32,0.035) 39px,rgba(42,35,32,0.035) 40px);
  pointer-events:none
}
.hero-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  align-items:center;max-width:var(--max-w);margin:0 auto;
  width:100%;position:relative;z-index:1
}
.hero-eyebrow{
  display:inline-block;font-size:0.72rem;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);border-bottom:1px solid var(--gold);padding-bottom:4px;
  margin-bottom:20px;font-family:var(--sans)
}
.hero-content h1{
  font-family:var(--serif);font-size:3.6rem;line-height:1.15;
  font-weight:700;margin-bottom:22px;color:var(--ink);font-style:italic
}
.hero-content h1 em{font-style:normal;color:var(--gold)}
.hero-content p{
  font-size:1rem;color:var(--mid);margin-bottom:36px;
  line-height:1.9;max-width:480px
}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual img{
  width:100%;height:auto;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);border:1px solid rgba(42,35,32,0.08)
}
/* floating ink decorations */
.hero-deco{
  position:absolute;opacity:0.04;color:var(--ink);
  font-family:var(--serif);font-size:7rem;pointer-events:none;
  animation:floatDeco 14s ease-in-out infinite
}
.hero-deco.d1{top:10%;left:2%;animation-delay:0s}
.hero-deco.d2{bottom:14%;right:3%;animation-delay:4s;font-size:5rem}
@keyframes floatDeco{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-18px) rotate(4deg)}}

/* ── Thin divider ─────────────────────────────────────────── */
.divider{
  display:flex;align-items:center;gap:20px;
  max-width:480px;margin:0 auto 0
}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:rgba(42,35,32,0.12)}
.divider span{font-size:0.7rem;letter-spacing:4px;text-transform:uppercase;color:var(--mid)}

/* ── Categories ───────────────────────────────────────────── */
.featured-products{background:var(--cream2)}
.categories-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:16px
}
.category-card{
  background:var(--white);border-radius:var(--radius);padding:32px 16px;
  text-align:center;transition:var(--trans);cursor:pointer;
  border:1px solid rgba(42,35,32,0.06);text-decoration:none;color:inherit
}
.category-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.category-card:hover .cat-icon-img{transform:scale(1.08)}
.cat-icon-img{width:56px;height:56px;margin:0 auto 14px;transition:var(--trans)}
.category-card h4{font-size:0.88rem;font-weight:600;margin-bottom:6px;font-family:var(--sans);letter-spacing:0.5px}
.category-card p{font-size:0.78rem;color:var(--mid);line-height:1.5}

/* ── Soap swatch feature ──────────────────────────────────── */
.soap-feature{background:var(--white)}
.soap-feature-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  align-items:center;max-width:var(--max-w);margin:0 auto
}
.soap-swatch-img{
  width:100%;border-radius:var(--radius);box-shadow:var(--shadow-md);
  border:1px solid rgba(42,35,32,0.07)
}
.soap-text .eyebrow{
  font-size:0.72rem;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;display:block;font-family:var(--sans)
}
.soap-text h2{font-family:var(--serif);font-size:2rem;margin-bottom:16px;font-style:italic}
.soap-text p{color:var(--mid);line-height:1.9;margin-bottom:24px;font-size:0.95rem}
.soap-bullets{margin:0 0 28px;display:flex;flex-direction:column;gap:8px}
.soap-bullets li{
  display:flex;align-items:center;gap:10px;font-size:0.9rem;color:var(--ink)
}
.soap-bullets li::before{content:'✦';color:var(--gold);font-size:0.6rem}

/* ── Instagram grid ───────────────────────────────────────── */
.instagram-gallery{background:var(--cream)}
.instagram-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.insta-card{
  border-radius:var(--radius-sm);overflow:hidden;position:relative;
  box-shadow:var(--shadow);transition:var(--trans);cursor:pointer;aspect-ratio:1
}
.insta-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.insta-card img{width:100%;height:100%;object-fit:cover;transition:var(--trans)}
.insta-card:hover img{transform:scale(1.06)}
.insta-overlay{
  position:absolute;inset:0;background:rgba(42,35,32,0);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;transition:var(--trans);color:var(--cream);opacity:0
}
.insta-card:hover .insta-overlay{background:rgba(42,35,32,0.42);opacity:1}
.insta-overlay svg{width:28px;height:28px}
.insta-overlay span{font-size:0.82rem;letter-spacing:1px}
.insta-follow-btn{text-align:center;margin-top:32px}

/* ── About preview ────────────────────────────────────────── */
.about-preview{background:var(--cream2)}
.about-preview-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:center;max-width:var(--max-w);margin:0 auto
}
.about-preview-image{
  border-radius:var(--radius);height:420px;
  background-size:cover;background-position:center;
  box-shadow:var(--shadow-md);position:relative
}
.about-preview-image::after{
  content:'';position:absolute;inset:0;border-radius:var(--radius);
  border:1px solid rgba(42,35,32,0.08)
}
.about-preview-text h3{font-family:var(--serif);font-size:1.9rem;margin-bottom:16px;font-style:italic}
.about-preview-text p{color:var(--mid);margin-bottom:14px;line-height:1.9;font-size:0.95rem}

/* ── Hours ────────────────────────────────────────────────── */
.hours-section{background:var(--white)}
.hours-card{
  max-width:480px;margin:0 auto;
  background:var(--cream);border-radius:var(--radius);padding:48px;
  box-shadow:var(--shadow-md);border:1px solid rgba(42,35,32,0.07);
  position:relative;overflow:hidden
}
.hours-card::before{
  content:'"';position:absolute;top:-10px;right:20px;font-size:8rem;
  color:var(--gold);opacity:0.08;font-family:Georgia,serif;line-height:1
}
.hours-card h4{
  text-align:center;font-size:1.1rem;margin-bottom:28px;
  color:var(--ink);font-family:var(--serif);letter-spacing:1px;font-style:italic
}
.hours-row{
  display:flex;justify-content:space-between;padding:12px 0;
  border-bottom:1px solid rgba(42,35,32,0.06)
}
.hours-row:last-child{border-bottom:none}
.hours-row .day{font-weight:500;font-size:0.9rem}
.hours-row .time{color:var(--mid);font-family:var(--sans);font-size:0.88rem}
.hours-row .closed{color:var(--gold);font-weight:600}
.hours-note{text-align:center;margin-top:18px;font-size:0.82rem;color:var(--mid);letter-spacing:1px}

/* ── Reviews ──────────────────────────────────────────────── */
.reviews-section{background:var(--cream2)}
.reviews-carousel{
  display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;padding-bottom:8px
}
.reviews-carousel::-webkit-scrollbar{display:none}
.review-card{
  flex:0 0 320px;scroll-snap-align:start;
  background:var(--white);padding:32px;border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid rgba(42,35,32,0.05)
}
.review-stars{color:var(--gold);font-size:0.9rem;margin-bottom:12px;letter-spacing:2px}
.review-text{font-size:0.9rem;color:var(--mid);line-height:1.8;margin-bottom:16px;font-style:italic}
.review-author{font-weight:600;font-size:0.88rem;color:var(--ink)}
.review-date{font-size:0.78rem;color:var(--mid);margin-top:2px}
.review-dots{display:flex;gap:8px;justify-content:center;margin-top:20px}
.review-dot{
  width:7px;height:7px;border-radius:50%;background:rgba(42,35,32,0.15);
  border:none;cursor:pointer;transition:var(--trans);padding:0
}
.review-dot.active{background:var(--gold);width:22px;border-radius:4px}
.review-nav{display:flex;gap:10px;justify-content:center;margin-top:14px}
.review-nav-btn{
  width:38px;height:38px;border-radius:50%;border:1px solid rgba(42,35,32,0.15);
  background:var(--white);font-size:1.1rem;cursor:pointer;transition:var(--trans);
  display:flex;align-items:center;justify-content:center;color:var(--ink)
}
.review-nav-btn:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* ── Quote ────────────────────────────────────────────────── */
.quote-section{
  background:var(--ink);text-align:center;padding:96px 28px;position:relative;overflow:hidden
}
.quote-section::before{
  content:'❧';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:18rem;color:var(--white);opacity:0.02;pointer-events:none
}
.quote-section blockquote{
  max-width:680px;margin:0 auto;font-family:var(--serif);font-size:1.4rem;
  font-style:italic;color:rgba(250,247,242,0.9);line-height:1.9;position:relative
}
.quote-section blockquote::before{
  content:'❝';font-size:4rem;color:var(--gold);opacity:0.4;
  position:absolute;top:-32px;left:-8px;font-style:normal;line-height:1
}
.quote-section cite{
  display:block;margin-top:24px;font-size:0.8rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--gold);font-style:normal
}

/* ── Footer ───────────────────────────────────────────────── */
.footer{
  background:var(--ink);color:rgba(250,247,242,0.65);
  padding:72px 28px 28px;position:relative
}
.footer::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)
}
.footer-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:40px;max-width:var(--max-w);margin:0 auto 40px
}
.footer-col h4{
  font-size:0.78rem;letter-spacing:4px;text-transform:uppercase;
  margin-bottom:16px;color:rgba(250,247,242,0.9);font-family:var(--sans)
}
.footer-col p,.footer-col a{font-size:0.86rem;line-height:2.3;color:rgba(250,247,242,0.5)}
.footer-col a:hover{color:var(--gold)}
.footer-social{display:flex;gap:10px;margin-top:14px}
.footer-social a{
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(250,247,242,0.15);
  display:inline-flex;align-items:center;justify-content:center;
  color:rgba(250,247,242,0.5);transition:var(--trans)
}
.footer-social a:hover{border-color:var(--gold);color:var(--gold)}
.footer-bottom{
  text-align:center;padding-top:28px;
  border-top:1px solid rgba(250,247,242,0.06);
  font-size:0.78rem;color:rgba(250,247,242,0.3);
  max-width:var(--max-w);margin:0 auto;letter-spacing:1px
}

/* ── Page header (inner pages) ────────────────────────────── */
.page-header{
  padding:calc(var(--header-h) + 72px) 28px 56px;text-align:center;
  background:var(--cream);position:relative;overflow:hidden
}
.page-header::after{
  content:'';position:absolute;bottom:0;left:0;width:100%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(42,35,32,0.12),transparent)
}
.page-header h1{font-family:var(--serif);font-size:2.6rem;margin-bottom:10px;font-style:italic}
.page-header p{color:var(--mid);font-size:0.96rem;max-width:460px;margin:0 auto}

/* ── Products page ────────────────────────────────────────── */
.filter-tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:44px}
.filter-tab{
  padding:8px 22px;border-radius:2px;background:transparent;
  border:1px solid rgba(42,35,32,0.15);font-family:var(--sans);
  font-size:0.78rem;font-weight:500;cursor:pointer;
  transition:var(--trans);color:var(--mid);letter-spacing:1.2px;text-transform:uppercase
}
.filter-tab:hover{border-color:var(--gold);color:var(--gold)}
.filter-tab.active{
  background:var(--ink);border-color:var(--ink);color:var(--cream)
}
.products-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px
}
.product-card{
  background:var(--white);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:var(--trans);
  border:1px solid rgba(42,35,32,0.05)
}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:rgba(201,169,110,0.3)}
.product-card .product-image{
  width:100%;height:240px;object-fit:cover;background:var(--light);
  transition:var(--trans)
}
.product-card:hover .product-image{transform:scale(1.04)}
.product-card .product-image-empty{display:flex;align-items:center;justify-content:center;font-size:2.6rem;color:#d8c9b0;background:#f5f1ec}
.product-card .product-info{padding:18px 20px}
.product-card .product-category{
  font-size:0.7rem;color:var(--gold);margin-bottom:4px;
  font-family:var(--sans);text-transform:uppercase;letter-spacing:2px;font-weight:600
}
.product-card .product-name{font-size:0.96rem;font-weight:600;margin-bottom:6px;color:var(--ink)}
.product-card .product-price{font-size:1rem;color:var(--mid);font-weight:600;font-family:var(--sans)}
.product-card a{color:inherit;display:block;overflow:hidden}

/* ── Product detail ───────────────────────────────────────── */
.product-detail{padding:calc(var(--header-h) + 72px) 28px 80px}
.product-detail-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;max-width:var(--max-w);margin:0 auto
}
.product-detail-main-image{
  width:100%;height:460px;object-fit:cover;border-radius:var(--radius);
  background:var(--light);box-shadow:var(--shadow-md)
}
.product-detail-thumbs{display:flex;gap:10px;margin-top:10px}
.product-detail-thumbs img{
  width:76px;height:76px;object-fit:cover;border-radius:var(--radius-sm);
  cursor:pointer;transition:var(--trans);border:2px solid transparent
}
.product-detail-thumbs img:hover,.product-detail-thumbs img.active{border-color:var(--gold)}
.product-detail-info h2{font-family:var(--serif);font-size:1.9rem;margin-bottom:10px;font-style:italic}
.product-detail-info .price{font-size:1.4rem;color:var(--gold);font-weight:700;font-family:var(--sans);margin-bottom:18px}
.product-detail-info .description{color:var(--mid);line-height:1.9;margin-bottom:22px;font-size:0.95rem}
.product-detail-info .meta{font-size:0.88rem;color:var(--mid);margin-bottom:6px}
.product-detail-info .meta strong{color:var(--ink)}
.back-link{display:inline-flex;align-items:center;gap:6px;margin-bottom:20px;color:var(--mid);font-size:0.88rem;transition:var(--trans)}
.back-link:hover{color:var(--gold)}

/* ── About page ───────────────────────────────────────────── */
.about-page{padding:calc(var(--header-h) + 56px) 28px 80px}
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:var(--max-w);margin:0 auto}
.about-story-image{border-radius:var(--radius);height:400px;background-size:cover;background-position:center;box-shadow:var(--shadow-lg)}
.about-story-text h3{font-family:var(--serif);font-size:1.8rem;margin-bottom:18px;font-style:italic}
.about-story-text p{color:var(--mid);margin-bottom:14px;line-height:1.9;font-size:0.95rem}
.about-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;max-width:var(--max-w);margin:56px auto 0}
.value-card{
  background:var(--white);padding:32px 22px;border-radius:var(--radius);
  text-align:center;box-shadow:var(--shadow);transition:var(--trans);
  border:1px solid rgba(42,35,32,0.05)
}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(201,169,110,0.25)}
.value-card .value-icon{font-size:2rem;margin-bottom:14px}
.value-card h4{font-size:1rem;margin-bottom:8px;font-family:var(--serif);font-style:italic}
.value-card p{font-size:0.88rem;color:var(--mid);line-height:1.7}

/* ── Contact page ─────────────────────────────────────────── */
.contact-page{padding:calc(var(--header-h) + 56px) 28px 80px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;max-width:var(--max-w);margin:0 auto}
.contact-info-cards{display:flex;flex-direction:column;gap:14px}
.contact-card{
  display:flex;gap:18px;background:var(--white);padding:22px;
  border-radius:var(--radius);box-shadow:var(--shadow);
  border:1px solid rgba(42,35,32,0.05);transition:var(--trans)
}
.contact-card:hover{transform:translateX(4px);box-shadow:var(--shadow-md)}
.contact-card .contact-icon{
  width:44px;height:44px;border-radius:50%;background:var(--cream2);
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
  color:var(--gold);flex-shrink:0
}
.contact-card h4{font-size:0.92rem;margin-bottom:3px;font-weight:600}
.contact-card p,.contact-card a{font-size:0.88rem;color:var(--mid)}
.contact-card a{color:var(--gold)}
.contact-form{background:var(--white);padding:38px;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.contact-form h3{font-family:var(--serif);font-size:1.3rem;margin-bottom:22px;font-style:italic}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:0.82rem;font-weight:500;margin-bottom:6px;letter-spacing:0.5px;color:var(--ink)}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:11px 14px;border:1px solid rgba(42,35,32,0.14);border-radius:var(--radius-sm);
  font-family:var(--sans);font-size:0.9rem;transition:var(--trans);
  background:var(--cream);color:var(--ink)
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,110,0.12)
}
.form-group textarea{height:120px;resize:vertical}
.form-success{
  display:none;background:rgba(138,158,124,0.1);color:var(--sage);
  padding:14px;border-radius:var(--radius-sm);text-align:center;margin-top:14px;font-weight:500
}
.form-success.show{display:block}
.map-container{max-width:var(--max-w);margin:40px auto 0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.map-container iframe{width:100%;height:360px;border:none;display:block}

/* ── WhatsApp float ───────────────────────────────────────── */
.whatsapp-float{
  position:fixed;bottom:28px;right:28px;z-index:900;
  width:52px;height:52px;border-radius:50%;
  background:var(--ink);color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 22px rgba(42,35,32,0.22);transition:var(--trans)
}
.whatsapp-float:hover{background:#25D366;color:var(--white);transform:scale(1.1)}

/* ── Cart float ───────────────────────────────────────────── */
.cart-float{
  position:fixed;bottom:90px;right:28px;z-index:901;
  width:52px;height:52px;border-radius:50%;
  background:var(--gold,#C9A24B);color:#fff;cursor:pointer;text-decoration:none;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 22px rgba(42,35,32,0.22);transition:var(--trans)
}
.cart-float:hover{transform:scale(1.1);color:#fff}
.cart-float svg{width:24px;height:24px}
.cart-float .cart-count{
  position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;box-sizing:border-box;
  border-radius:10px;background:#e0566f;color:#fff;font-size:.72rem;font-weight:700;line-height:1;
  display:none;align-items:center;justify-content:center
}
.cart-float .cart-count.show{display:flex}

/* ── Back to top ──────────────────────────────────────────── */
.back-to-top{
  position:fixed;bottom:152px;right:28px;z-index:900;
  width:40px;height:40px;border-radius:50%;
  background:var(--white);border:1px solid rgba(42,35,32,0.14);
  color:var(--ink);font-size:1.1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);transition:var(--trans);opacity:0;visibility:hidden
}
.back-to-top.visible{opacity:1;visibility:visible}
.back-to-top:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* ── Animations ───────────────────────────────────────────── */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity 0.7s ease,transform 0.7s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-left{opacity:0;transform:translateX(-32px);transition:opacity 0.7s ease,transform 0.7s ease}
.fade-in-left.visible{opacity:1;transform:translateX(0)}
.fade-in-right{opacity:0;transform:translateX(32px);transition:opacity 0.7s ease,transform 0.7s ease}
.fade-in-right.visible{opacity:1;transform:translateX(0)}
.fade-in-scale{opacity:0;transform:scale(0.96);transition:opacity 0.7s ease,transform 0.7s ease}
.fade-in-scale.visible{opacity:1;transform:scale(1)}
.delay-1{transition-delay:0.12s}.delay-2{transition-delay:0.22s}.delay-3{transition-delay:0.32s}

/* ── Responsive ───────────────────────────────────────────── */
@media(max-width:1024px){
  .categories-grid{grid-template-columns:repeat(3,1fr)}
  .soap-feature-grid{grid-template-columns:1fr;gap:36px}
  .hero-content h1{font-size:2.8rem}
}
@media(max-width:768px){
  :root{ --header-h: 64px; }
  .hero{padding:100px 20px 60px;text-align:center}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-buttons{justify-content:center}
  .hero-content p{max-width:none}
  .hero-visual{max-width:380px;margin:0 auto}
  .nav-toggle{display:block}
  .nav-links{
    display:none;position:fixed;top:0;right:0;height:100vh;width:72vw;max-width:300px;
    background:var(--cream);flex-direction:column;align-items:flex-start;
    padding:80px 32px 32px;gap:18px;box-shadow:-8px 0 40px rgba(42,35,32,0.1);
    z-index:999;transition:transform 0.4s ease;transform:translateX(100%)
  }
  .nav-links.open{display:flex;transform:translateX(0)}
  .nav-links a{font-size:1rem}
  .categories-grid{grid-template-columns:repeat(2,1fr)}
  .instagram-grid{grid-template-columns:repeat(2,1fr)}
  .about-preview-grid,.about-story,.contact-grid,.product-detail-grid{grid-template-columns:1fr}
  .section{padding:64px 0}
  .section-title{font-size:1.8rem}
  .hero-content h1{font-size:2.2rem}
}
@media(max-width:480px){
  .categories-grid{grid-template-columns:1fr 1fr}
  .instagram-grid{grid-template-columns:1fr 1fr}
  .hero-content h1{font-size:1.9rem}
}

/* ── Focus & motion ───────────────────────────────────────── */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:3px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .fade-in,.fade-in-left,.fade-in-right,.fade-in-scale{opacity:1;transform:none}
}


/* === NEW: Product Search === */
.products-search{max-width:480px;margin:0 auto 24px;position:relative}
.search-box{display:flex;align-items:center;background:var(--white);border:1.5px solid #e0dbd5;border-radius:40px;padding:0 18px;transition:border-color .25s}
.search-box:focus-within{border-color:var(--gold)}
.search-icon{flex-shrink:0;color:var(--mid);margin-right:10px}
.search-box input{flex:1;border:none;outline:none;background:transparent;padding:12px 0;font-family:var(--sans);font-size:.9rem;color:var(--ink)}
.search-box input::placeholder{color:#bbb}
.search-clear{display:none;background:none;border:none;font-size:1.2rem;color:var(--mid);cursor:pointer;padding:4px;line-height:1}
.search-clear.show{display:block}

/* === NEW: Product Badges === */
.product-card{position:relative}
.product-badge{position:absolute;top:12px;left:12px;z-index:2;padding:4px 10px;font-size:.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;border-radius:4px;color:var(--white);pointer-events:none}
.badge-new{background:#5a9e6f}
.badge-bestseller{background:#d46a6a}
.badge-sale{background:#e89a3c}

/* === Sold-out states === */
.product-card .soldout-overlay{position:absolute;top:0;left:0;right:0;height:240px;display:flex;align-items:center;justify-content:center;background:rgba(42,35,32,.5);color:#fff;font-weight:700;font-size:1.05rem;letter-spacing:2px;pointer-events:none}
.product-card.is-soldout .product-image{filter:grayscale(35%)}
.add-cart-btn.is-soldout,.add-cart-btn:disabled{opacity:.4;cursor:not-allowed}
.product-detail-images{position:relative}
.detail-soldout-overlay{position:absolute;top:14px;left:14px;background:rgba(42,35,32,.85);color:#fff;font-weight:700;font-size:.9rem;letter-spacing:2px;padding:6px 14px;border-radius:6px;z-index:5}
.color-swatch{position:relative}
.color-swatch.soldout{opacity:.55}
.color-swatch.soldout img,.color-swatch.soldout .swatch-blank{filter:grayscale(70%)}
.color-swatch .swatch-sold{position:absolute;top:2px;left:50%;transform:translateX(-50%);background:#c0392b;color:#fff;font-size:.58rem;font-weight:700;padding:1px 5px;border-radius:6px;white-space:nowrap}
.btn-add-cart:disabled,.btn-add-cart.is-soldout{opacity:.45;cursor:not-allowed}
.cart-toast.soldout .toast-check{background:#c0392b}

/* === NEW: Detail Options (Color, Quantity) === */
.detail-options{margin-bottom:18px}
.option-label{display:block;font-weight:600;font-size:.82rem;margin-bottom:8px;color:var(--ink);text-transform:uppercase;letter-spacing:1px}
.color-choices{display:flex;flex-wrap:wrap;gap:8px}
.color-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border:1.5px solid #e0dbd5;border-radius:30px;font-size:.8rem;cursor:pointer;transition:all .2s;background:var(--white);font-family:var(--sans)}
.color-chip:hover{border-color:var(--gold)}
.color-chip.active{border-color:var(--gold);background:rgba(201,169,110,0.1);color:var(--gold-d);font-weight:600}
/* Color swatches: small square photo + name; clicking swaps the main image */
.color-swatch{display:inline-flex;flex-direction:column;align-items:center;gap:5px;width:76px;padding:6px 5px;border:1.5px solid #e0dbd5;border-radius:10px;background:var(--white);cursor:pointer;transition:all .18s;font-family:var(--sans)}
.color-swatch img,.color-swatch .swatch-blank{width:62px;height:62px;border-radius:7px;object-fit:cover}
.color-swatch .swatch-blank{display:flex;align-items:center;justify-content:center;background:#f5f1ec;font-size:1.5rem}
.color-swatch .swatch-name{font-size:.72rem;line-height:1.2;color:var(--ink,#3a322c);text-align:center;word-break:break-word}
.color-swatch:hover{border-color:var(--gold);transform:translateY(-1px)}
.color-swatch.active{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,169,110,.28)}

/* === NEW: Quantity Selector === */
.qty-row{display:flex;align-items:center;gap:0;max-width:160px}
.qty-btn{width:40px;height:40px;border:1.5px solid #e0dbd5;background:var(--white);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:var(--sans);color:var(--ink)}
.qty-btn:first-child{border-radius:8px 0 0 8px}
.qty-btn:last-child{border-radius:0 8px 8px 0}
.qty-btn:hover{background:var(--light)}
.qty-input{width:60px;height:40px;border:1.5px solid #e0dbd5;border-left:none;border-right:none;text-align:center;font-family:var(--sans);font-size:.9rem;font-weight:600;color:var(--ink);outline:none;-moz-appearance:textfield}
.qty-input::-webkit-inner-spin-button,.qty-input::-webkit-outer-spin-button{-webkit-appearance:none}

/* === NEW: Bulk Calculator === */
.bulk-calc{margin-top:14px;padding:16px;background:var(--light);border-radius:10px;border:1px solid #e8e3dd}
.bulk-tier{font-size:.82rem;color:var(--mid);margin-bottom:6px}
.bulk-tier span{font-weight:600;color:var(--ink)}
.bulk-savings{font-size:.82rem;color:var(--sage);font-weight:600;margin-bottom:4px}
.bulk-total{font-size:1.1rem;font-weight:700;color:var(--ink);font-family:var(--serif)}


/* === Shopping Cart === */
.cart-icon-btn{position:relative;background:none;border:none;cursor:pointer;padding:6px;color:var(--ink);transition:var(--trans)}
.cart-icon-btn:hover{color:var(--gold)}
.cart-icon-btn svg{width:22px;height:22px}
.cart-count{position:absolute;top:-2px;right:-4px;background:var(--gold);color:var(--white);font-size:.6rem;font-weight:700;min-width:16px;height:16px;line-height:16px;text-align:center;border-radius:8px;display:none}
.cart-count.show{display:block}

/* Cart Sidebar */
.cart-overlay{position:fixed;inset:0;background:rgba(42,35,32,0.4);z-index:2000;opacity:0;visibility:hidden;transition:all .3s ease}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-sidebar{position:fixed;top:0;right:-400px;width:380px;max-width:90vw;height:100vh;background:var(--white);z-index:2001;display:flex;flex-direction:column;transition:right .35s cubic-bezier(0.25,0.46,0.45,0.94);box-shadow:-8px 0 30px rgba(0,0,0,0.12)}
.cart-sidebar.open{right:0}

.cart-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e8e3dd;flex-shrink:0}
.cart-header h3{font-family:var(--serif);font-size:1.1rem;font-weight:700}
.cart-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--mid);padding:4px}
.cart-close:hover{color:var(--ink)}

.cart-items{flex:1;overflow-y:auto;padding:16px 24px}
.cart-empty{text-align:center;padding:60px 20px;color:var(--mid)}
.cart-empty .empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.5}
.cart-empty p{font-size:.88rem}

.cart-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid #f0ebe5;animation:cartSlideIn .3s ease}
@keyframes cartSlideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.cart-item-img{width:56px;height:56px;border-radius:8px;object-fit:cover;background:var(--light);flex-shrink:0}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.cart-item-price{font-size:.75rem;color:var(--mid)}
.cart-item-color{font-size:.7rem;color:var(--gold-d)}
.cart-item-qty{display:flex;align-items:center;gap:0;margin-top:6px}
.cart-qty-btn{width:26px;height:26px;border:1px solid #ddd;background:var(--white);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s}
.cart-qty-btn:hover{background:var(--light)}
.cart-qty-val{width:32px;text-align:center;font-size:.82rem;font-weight:600}
.cart-item-remove{background:none;border:none;color:var(--mid);cursor:pointer;font-size:.75rem;padding:4px;margin-left:auto;align-self:flex-start;flex-shrink:0}
.cart-item-remove:hover{color:var(--danger)}

.cart-footer{padding:20px 24px;border-top:1px solid #e8e3dd;flex-shrink:0;background:var(--white)}
.cart-total{display:flex;justify-content:space-between;margin-bottom:14px;font-size:.95rem}
.cart-total-label{font-weight:500;color:var(--mid)}
.cart-total-value{font-weight:700;font-size:1.05rem}
.cart-whatsapp-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:#25D366;color:var(--white);border:none;border-radius:10px;font-family:var(--sans);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.5px}
.cart-whatsapp-btn:hover{background:#1EBE57;transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,211,102,0.3)}
.cart-whatsapp-btn svg{width:20px;height:20px}
.cart-clear-btn{display:block;width:100%;padding:8px;margin-top:8px;background:none;border:1px solid #ddd;color:var(--mid);border-radius:8px;font-size:.78rem;cursor:pointer;transition:all .2s}
.cart-clear-btn:hover{border-color:var(--danger);color:var(--danger)}

/* Add to cart button in product cards */
.product-card .add-cart-btn{
  position:absolute;bottom:12px;right:12px;width:36px;height:36px;border-radius:50%;
  background:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,0.1);transition:all .25s;opacity:0;transform:translateY(8px);z-index:3
}
.product-card:hover .add-cart-btn{opacity:1;transform:translateY(0)}
.product-card .add-cart-btn:hover{background:var(--ink);color:var(--white);transform:translateY(0) scale(1.1)}
.product-card .add-cart-btn svg{width:16px;height:16px}

/* Add to cart in product detail */
.detail-add-cart{margin-top:6px;display:flex;gap:10px;align-items:center}
.detail-add-cart .btn-add-cart{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--ink);color:var(--cream);border:none;border-radius:8px;font-family:var(--sans);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}
.detail-add-cart .btn-add-cart:hover{background:#3E3330;transform:translateY(-1px)}
.detail-add-cart .btn-add-cart svg{width:18px;height:18px}

/* Cart toast notification */
.cart-toast{position:fixed;bottom:90px;right:24px;background:var(--ink);color:var(--cream);padding:12px 20px;border-radius:10px;font-size:.85rem;z-index:3000;opacity:0;transform:translateY(10px);transition:all .3s;pointer-events:none;display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.cart-toast.show{opacity:1;transform:translateY(0)}
.cart-toast .toast-check{color:#5a9e6f;font-weight:700}

/* Responsive */
@media(max-width:768px){
  .cart-sidebar{width:100%;max-width:100vw;right:-100%}
  .product-card .add-cart-btn{opacity:1;transform:translateY(0)}
  .cart-icon-btn{padding:4px}
  .cart-icon-btn svg{width:20px;height:20px}
}
