/* ===== Bon Bagay Boutique — vibrant urban / Caribbean ===== */
:root{
  --red:#d93232;
  --red-dk:#a82424;
  --gold:#f4c542;
  --black:#0d0d0d;
  --paper:#fff;
  --soft:#f8f3eb;
  --soft-dk:#ede4d3;
  --ink:#1a1a1a;
  --ink-soft:#5a4a3a;
  --line:#e7dccb;
  --shadow:0 6px 24px rgba(20,15,10,.08);
  --shadow-lg:0 24px 60px rgba(20,15,10,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Archivo',system-ui,sans-serif;color:var(--ink);background:var(--soft);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--red)}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.8rem;border-radius:8px;font-weight:700;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase;transition:all .2s;cursor:pointer;border:none;font-family:inherit}
.btn-red{background:var(--red);color:#fff;box-shadow:0 6px 18px rgba(217,50,50,.32)}
.btn-red:hover{background:var(--red-dk);transform:translateY(-2px)}
.btn-light{background:var(--paper);color:var(--ink);border:2px solid var(--ink)}
.btn-light:hover{background:var(--ink);color:#fff}

/* Nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(248,243,235,.94);backdrop-filter:blur(12px);border-bottom:2px solid var(--black)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-mark{width:46px;height:46px;border-radius:8px;background:var(--red);color:var(--gold);display:grid;place-items:center;font-size:1.6rem;font-weight:700;box-shadow:var(--shadow)}
.brand-name{font-family:'Archivo Black',sans-serif;font-size:1.4rem;letter-spacing:-.01em}
.brand-sub{font-size:.7rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.12em}
.nav-links{display:flex;gap:1.6rem;list-style:none}
.nav-links a{font-size:.85rem;font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;transition:color .2s}
.nav-links a:hover{color:var(--red)}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-cta .btn{padding:.65rem 1.2rem;font-size:.74rem}
.lang-toggle{display:inline-flex;align-items:center;gap:.15rem;border:2px solid var(--black);border-radius:8px;padding:.2rem;background:var(--soft)}
.lang-toggle button{background:transparent;border:none;padding:.35rem .65rem;border-radius:5px;font:700 .68rem/1 inherit;letter-spacing:.06em;cursor:pointer;color:var(--ink-soft);opacity:.7;transition:all .2s;font-family:inherit}
.lang-toggle button.active{background:var(--red);color:var(--gold);opacity:1}
.lang-toggle button:hover{opacity:1}
.burger{display:none;width:40px;height:40px;background:transparent;border:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;cursor:pointer}
.burger span{width:22px;height:2.5px;background:var(--ink);border-radius:2px;transition:.25s}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hero */
.hero{position:relative;padding:6rem 0 5rem;overflow:hidden;background:var(--soft)}
.hero-blob{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(244,197,66,.4),transparent 70%);top:-200px;right:-150px;z-index:0}
.hero-inner{position:relative;z-index:2;text-align:center;max-width:880px;margin:0 auto}
.hero-tag{display:inline-block;background:var(--black);color:var(--gold);padding:.55rem 1.2rem;border-radius:999px;font-size:.74rem;font-weight:600;margin-bottom:1.6rem;letter-spacing:.08em}
.hero h1{font-family:'Archivo Black',sans-serif;font-size:clamp(2.6rem,7vw,5.6rem);line-height:1;letter-spacing:-.02em;margin-bottom:1.4rem}
.hero h1 em{font-family:'Archivo Black',sans-serif;font-style:italic;color:var(--red);text-decoration:underline;text-decoration-color:var(--gold);text-decoration-thickness:6px;text-underline-offset:8px}
.hero-desc{font-size:1.1rem;color:var(--ink-soft);max-width:600px;margin:0 auto 2rem}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-strip{display:flex;justify-content:center;align-items:center;gap:.8rem;flex-wrap:wrap;font-size:.82rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);font-weight:600}
.hero-strip .dot{color:var(--red);font-size:.7rem}

/* Sections common */
section{padding:5rem 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 3.5rem}
.section-kicker{display:inline-block;font-size:.78rem;color:var(--red);margin-bottom:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em}
.section-title{font-family:'Archivo Black',sans-serif;font-size:clamp(2rem,5vw,3.6rem);line-height:1.05;text-align:center;margin-bottom:.8rem;letter-spacing:-.01em}
.section-title.left{text-align:left}
.section-sub{color:var(--ink-soft);font-size:1.05rem}

/* About */
.about{background:var(--paper)}
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:center}
.about-text p{margin-bottom:1.1rem;color:var(--ink-soft);font-size:1.02rem}
.about-img{aspect-ratio:4/5;overflow:hidden;border-radius:14px;box-shadow:var(--shadow-lg);border:4px solid var(--black)}
.about-img img{width:100%;height:100%;object-fit:cover}

/* Shop */
.shop{background:var(--soft-dk)}
.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.cat-card{aspect-ratio:3/4;background-size:cover;background-position:center;border-radius:12px;overflow:hidden;position:relative;display:flex;align-items:flex-end;padding:1.5rem;box-shadow:var(--shadow);transition:transform .3s;border:3px solid var(--black)}
.cat-card:hover{transform:translateY(-6px)}
.cat-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(13,13,13,.85) 100%)}
.cat-info{position:relative;color:#fff;z-index:2}
.cat-info h3{font-family:'Archivo Black',sans-serif;font-size:1.4rem;margin-bottom:.2rem}
.cat-info span{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);font-weight:600}

/* Locations */
.locations{background:var(--paper)}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.loc-card{background:var(--soft);border:3px solid var(--black);padding:2.5rem 2rem;border-radius:14px;position:relative;transition:transform .3s}
.loc-card:hover{transform:translateY(-4px);background:var(--gold)}
.loc-num{position:absolute;top:-22px;left:24px;width:44px;height:44px;background:var(--red);color:#fff;display:grid;place-items:center;border-radius:50%;font-family:'Archivo Black',sans-serif;font-size:1rem;border:3px solid var(--black)}
.loc-card h3{font-family:'Archivo Black',sans-serif;font-size:1.6rem;margin-bottom:.6rem}
.loc-addr{color:var(--ink-soft);margin-bottom:1.4rem;font-size:.96rem}
.loc-link{font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.1em;font-size:.84rem;display:inline-flex;align-items:center;gap:.4rem;transition:gap .25s}
.loc-link:hover{gap:.8rem}

/* Social */
.social{background:var(--black);color:var(--soft)}
.social .section-title{color:var(--soft)}
.social .section-title em{color:var(--gold)}
.social .section-kicker{color:var(--gold)}
.social .section-sub{color:rgba(248,243,235,.7)}
.social-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.soc-card{background:rgba(255,255,255,.06);padding:2rem;border-radius:14px;text-align:center;border:1px solid rgba(255,255,255,.1);transition:all .3s}
.soc-card:hover{background:var(--red);border-color:var(--red);transform:translateY(-6px)}
.soc-icon{font-size:2.4rem;margin-bottom:.8rem}
.soc-card h3{font-family:'Archivo Black',sans-serif;font-size:1.2rem;margin-bottom:.3rem}
.soc-card span{font-size:.85rem;color:rgba(248,243,235,.7)}
.soc-card:hover span{color:#fff}

/* Reviews */
.reviews{background:var(--soft)}
.rating-big{margin-top:1.5rem}
.rating-big .stars{color:var(--gold);font-size:1.8rem;letter-spacing:.1em;-webkit-text-stroke:1px var(--red)}
.rating-big .meta{font-size:.82rem;color:var(--ink-soft);margin-top:.4rem;text-transform:uppercase;letter-spacing:.14em;font-weight:600}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.rev-card{background:var(--paper);padding:2rem;border-radius:12px;box-shadow:var(--shadow);border-top:5px solid var(--red)}
.rev-stars{color:var(--gold);margin-bottom:1rem;letter-spacing:.1em;-webkit-text-stroke:1px var(--red)}
.rev-card p{color:var(--ink);margin-bottom:1.4rem;font-style:italic}
.rev-person{display:flex;align-items:center;gap:.8rem}
.rev-avatar{width:42px;height:42px;border-radius:8px;background:var(--red);color:var(--gold);display:grid;place-items:center;font-weight:700;font-family:'Archivo Black',sans-serif}
.rev-name{font-weight:700;font-size:.95rem}
.rev-when{font-size:.72rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.1em}

/* Contact */
.contact{background:var(--paper)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-list{list-style:none;margin:1.5rem 0;border-top:1px solid var(--line)}
.contact-list li{display:flex;justify-content:space-between;padding:1rem 0;border-bottom:1px solid var(--line);gap:1rem}
.contact-list strong{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);font-weight:700}
.contact-list a,.contact-list span{font-weight:600;text-align:right}
.contact-list a:hover{color:var(--red)}
.contact-ctas{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1rem}
.map-wrap{border-radius:14px;overflow:hidden;box-shadow:var(--shadow-lg);min-height:380px;border:3px solid var(--black)}
.map-wrap iframe{width:100%;height:100%;border:none;min-height:380px}

/* Footer */
.footer{background:var(--black);color:var(--soft);padding:4rem 0 2rem}
.footer .brand-name{color:var(--soft)}
.footer .brand-sub{color:rgba(248,243,235,.6)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.ft-about{margin-top:1rem;color:rgba(248,243,235,.7);font-size:.95rem}
.footer h5{font-family:'Archivo Black',sans-serif;font-size:1rem;margin-bottom:1rem;color:var(--gold);text-transform:uppercase}
.footer ul{list-style:none}
.footer ul li{padding:.4rem 0;font-size:.92rem;color:rgba(248,243,235,.7)}
.footer ul li a:hover{color:var(--red)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:2rem;border-top:1px solid rgba(248,243,235,.15);font-size:.78rem;color:rgba(248,243,235,.5);text-transform:uppercase;letter-spacing:.12em}

/* Reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s,transform .8s}
.reveal.in{opacity:1;transform:none}
.reveal.delay-1{transition-delay:.12s}
.reveal.delay-2{transition-delay:.24s}
.reveal.delay-3{transition-delay:.36s}

/* Mobile */
@media (max-width:900px){
  .nav-links{display:none;position:fixed;top:74px;left:0;right:0;flex-direction:column;background:var(--soft);padding:1.5rem;gap:.4rem;box-shadow:var(--shadow-lg);border-bottom:2px solid var(--black)}
  .nav-links.open{display:flex}
  .burger{display:flex}
  .nav-cta .btn{display:none}
  .about-grid,.contact-grid,.loc-grid{grid-template-columns:1fr;gap:2.5rem}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .shop-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}
  .review-grid,.social-grid{grid-template-columns:1fr;gap:1rem}
  section{padding:4rem 0}
  .hero{padding:3rem 0 4rem}
  .hero h1{font-size:clamp(2.4rem,11vw,4.4rem)}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .hero-ctas .btn{width:100%}
  .hero-strip{font-size:.7rem;gap:.4rem}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
  .map-wrap{min-height:280px}
  .map-wrap iframe{min-height:280px}
}
@media (max-width:480px){
  .container{padding:0 1.1rem}
  .shop-grid{grid-template-columns:1fr}
  .cat-card{aspect-ratio:5/4}
  .contact-list li{flex-direction:column;align-items:flex-start;gap:.3rem}
  .contact-list a,.contact-list span{text-align:left}
}
