/* ============================================================
   OH SO BLESSED — Brand Stylesheet
   Primary: Purple #6B3FA0 | Lavender #9B7EC8 | Light #E8D5F5
   Accent: Teal #2A7B7B | Gold #C9A84C | Blush #F5D5E0
   Fonts: Playfair Display (display) + DM Sans (body)
   Brand Promise: Made with Prayer. Created with Purpose.
   ============================================================ */

:root {
  --purple:       #6B3FA0;
  --purple-deep:  #4A2570;
  --purple-mid:   #8B5EC8;
  --purple-soft:  #9B7EC8;
  --lavender:     #C4A8E0;
  --lavender-pale:#E8D5F5;
  --lavender-bg:  #F5EEF8;
  --blush:        #F5D5E0;
  --blush-pale:   #FDF0F4;
  --gold:         #C9A84C;
  --gold-light:   #E8C96B;
  --gold-pale:    #FBF3DC;
  --teal:         #2A7B7B;
  --teal-light:   #3aabab;
  --teal-pale:    #EAF5F5;
  --cream:        #FDFAF6;
  --white:        #FFFFFF;
  --text:         #1C1A2E;
  --text-mid:     #4A4560;
  --text-muted:   #8A85A0;
  --border:       rgba(107,63,160,0.12);
  --shadow-xs:    0 2px 8px rgba(107,63,160,0.08);
  --shadow-sm:    0 4px 20px rgba(107,63,160,0.10);
  --shadow-md:    0 12px 40px rgba(107,63,160,0.14);
  --shadow-lg:    0 24px 60px rgba(107,63,160,0.18);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--cream);
  color:var(--text);
  overflow-x:hidden;
  line-height:1.65;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}

/* ── NAV ── */
.osb-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:70px;padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(253,250,246,0.95);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(107,63,160,0.12);
  transition:box-shadow 0.3s;
}
.osb-nav.scrolled{box-shadow:0 2px 24px rgba(107,63,160,0.1);}

.nav-logo{
  display:flex;align-items:center;gap:0.5rem;
  font-family:'Playfair Display',serif;
  font-size:1.3rem;font-weight:700;
  color:var(--purple-deep);letter-spacing:0.01em;
}
.nav-logo-icon{font-size:1.2rem;}
.nav-logo span{color:var(--purple);}

.nav-links{display:flex;align-items:center;gap:0.1rem;}
.nav-links a{
  font-size:0.8rem;font-weight:600;color:var(--text-mid);
  padding:0.45rem 0.75rem;border-radius:8px;
  transition:color 0.2s,background 0.2s;
}
.nav-links a:hover{color:var(--purple);background:rgba(107,63,160,0.06);}
.nav-links a.active{color:var(--purple);font-weight:700;}
.nav-cta{
  background:var(--purple)!important;color:white!important;
  padding:0.5rem 1.1rem!important;border-radius:8px!important;
  font-weight:700!important;transition:background 0.2s!important;
  margin-left:0.3rem;
}
.nav-cta:hover{background:var(--purple-deep)!important;}

.nav-hamburger{
  display:none;flex-direction:column;gap:5px;
  cursor:pointer;padding:4px;background:none;border:none;
}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--purple);border-radius:99px;}
.nav-mobile{
  display:none;position:fixed;
  top:70px;left:0;right:0;
  background:var(--white);border-bottom:1px solid var(--border);
  padding:1.5rem 5%;z-index:199;
  flex-direction:column;gap:0.3rem;
  box-shadow:0 8px 30px rgba(107,63,160,0.1);
}
.nav-mobile.open{display:flex;}
.nav-mobile a{
  font-size:0.92rem;font-weight:500;color:var(--text-mid);
  padding:0.7rem 0;border-bottom:1px solid var(--border);
}
.nav-mobile a:last-child{border:none;color:var(--purple);font-weight:700;}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-family:'DM Sans',sans-serif;font-size:0.9rem;font-weight:700;
  padding:0.85rem 1.8rem;border-radius:10px;border:none;
  cursor:pointer;transition:all 0.25s;letter-spacing:0.01em;
  white-space:nowrap;text-decoration:none;
}
.btn .arr{transition:transform 0.2s;}
.btn:hover .arr{transform:translateX(4px);}

.btn-purple{
  background:var(--purple);color:white;
  box-shadow:0 4px 16px rgba(107,63,160,0.28);
}
.btn-purple:hover{background:var(--purple-deep);transform:translateY(-2px);box-shadow:0 8px 24px rgba(107,63,160,0.38);}

.btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--purple-deep);
  box-shadow:0 4px 16px rgba(201,168,76,0.28);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,0.4);}

.btn-outline{
  background:transparent;color:var(--purple);
  border:2px solid rgba(107,63,160,0.25);
}
.btn-outline:hover{border-color:var(--purple);background:rgba(107,63,160,0.05);}

.btn-white{
  background:white;color:var(--purple-deep);
  box-shadow:0 4px 16px rgba(0,0,0,0.1);
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.15);}

.btn-outline-white{
  background:transparent;color:white;
  border:2px solid rgba(255,255,255,0.4);
}
.btn-outline-white:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.7);}

/* ── LAYOUT ── */
.section{padding:6rem 5%;}
.section-inner{max-width:1200px;margin:0 auto;}
.section-white{background:var(--white);}
.section-cream{background:var(--cream);}
.section-lavender{background:var(--lavender-bg);}
.section-purple{background:var(--purple-deep);}
.section-blush{background:var(--blush-pale);}

/* ── TYPOGRAPHY ── */
.eyebrow{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-size:0.68rem;font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--purple);margin-bottom:0.8rem;
}
.eyebrow::before{content:'♥';font-size:0.7rem;}
.eyebrow-gold{color:var(--gold);}
.eyebrow-gold::before{color:var(--gold);}
.eyebrow-teal{color:var(--teal);}
.eyebrow-teal::before{color:var(--teal);}
.eyebrow-white{color:rgba(255,255,255,0.7);}
.eyebrow-white::before{color:rgba(255,255,255,0.5);}

.h1{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,5vw,3.8rem);font-weight:700;line-height:1.1;color:var(--purple-deep);}
.h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;line-height:1.15;color:var(--purple-deep);}
.h3{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;line-height:1.2;color:var(--purple-deep);}
.h1 em,.h2 em,.h3 em{font-style:italic;color:var(--purple);}
.white-text{color:white!important;}
.white-text em{color:var(--lavender)!important;}

.body-lg{font-size:1.05rem;line-height:1.78;color:var(--text-mid);}
.body-md{font-size:0.92rem;line-height:1.75;color:var(--text-mid);}
.body-sm{font-size:0.82rem;line-height:1.7;color:var(--text-muted);}

/* ── SHIMMER BAR ── */
.shimmer-bar{
  height:4px;
  background:linear-gradient(90deg,var(--purple),var(--lavender),var(--gold),var(--lavender),var(--purple));
  background-size:200% 100%;
  animation:shimmer 3s linear infinite;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── CARDS ── */
.card{
  background:var(--white);border-radius:18px;
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  overflow:hidden;transition:transform 0.3s,box-shadow 0.3s;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}

/* ── PRODUCT CARD ── */
.prod-card{
  background:white;border-radius:18px;overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--shadow-xs);
  transition:all 0.3s;position:relative;
}
.prod-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.prod-img{
  height:220px;display:flex;align-items:center;
  justify-content:center;position:relative;overflow:hidden;
  font-size:3rem;
}
.prod-badge{
  position:absolute;top:0.8rem;right:0.8rem;
  font-size:0.62rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.08em;padding:0.28rem 0.65rem;border-radius:99px;
}
.pb-new{background:var(--purple);color:white;}
.pb-custom{background:var(--gold);color:var(--purple-deep);}
.pb-sale{background:#e74c3c;color:white;}
.pb-popular{background:var(--teal);color:white;}
.prod-body{padding:1.2rem 1.4rem 1.4rem;}
.prod-category{font-size:0.64rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--purple-soft);margin-bottom:0.3rem;}
.prod-name{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--purple-deep);margin-bottom:0.4rem;line-height:1.3;}
.prod-desc{font-size:0.78rem;color:var(--text-mid);line-height:1.6;margin-bottom:0.8rem;}
.prod-footer{display:flex;justify-content:space-between;align-items:center;padding-top:0.8rem;border-top:1px solid var(--border);}
.prod-price{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--purple);}
.prod-price-note{font-size:0.65rem;color:var(--text-muted);font-weight:400;display:block;margin-top:-2px;}
.prod-action{
  font-size:0.76rem;font-weight:700;color:var(--purple);
  display:inline-flex;align-items:center;gap:0.3rem;
  transition:gap 0.2s,color 0.2s;
}
.prod-card:hover .prod-action{gap:0.6rem;color:var(--purple-deep);}

/* ── FORM ELEMENTS ── */
.form-group{margin-bottom:1.1rem;}
.form-label{display:block;font-size:0.76rem;font-weight:700;color:var(--purple);margin-bottom:0.4rem;letter-spacing:0.02em;}
.form-input{
  width:100%;padding:0.78rem 1rem;
  border:1.5px solid rgba(107,63,160,0.18);border-radius:9px;
  font-family:'DM Sans',sans-serif;font-size:0.88rem;color:var(--text);
  background:var(--lavender-bg);outline:none;
  transition:border-color 0.2s,background 0.2s;
}
.form-input:focus{border-color:var(--purple);background:white;}
.form-input::placeholder{color:var(--text-muted);}
textarea.form-input{resize:vertical;min-height:120px;}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B3FA0' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;}
.form-fine{font-size:0.7rem;color:var(--text-muted);margin-top:0.7rem;line-height:1.5;}

/* ── PAGE HERO ── */
.page-hero{
  padding:9rem 5% 5rem;
  background:linear-gradient(150deg,var(--lavender-bg) 0%,var(--blush-pale) 50%,var(--gold-pale) 100%);
  border-bottom:1px solid var(--border);position:relative;overflow:hidden;
}
.page-hero::before{
  content:'♥';position:absolute;
  font-size:30rem;color:rgba(107,63,160,0.03);
  top:50%;right:-5%;transform:translateY(-50%);
  line-height:1;pointer-events:none;
}
.page-hero .inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;}
.page-hero h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.2rem,4.5vw,3.4rem);
  font-weight:700;line-height:1.12;color:var(--purple-deep);margin-bottom:1rem;
}
.page-hero h1 em{font-style:italic;color:var(--purple);}
.page-hero p{font-size:1rem;color:var(--text-mid);line-height:1.75;max-width:540px;margin-bottom:2rem;}

/* ── SCROLL REVEAL ── */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity 0.65s ease,transform 0.65s cubic-bezier(0.22,1,0.36,1);}
[data-reveal].revealed{opacity:1;transform:translateY(0);}
[data-reveal-delay="1"]{transition-delay:0.1s;}
[data-reveal-delay="2"]{transition-delay:0.2s;}
[data-reveal-delay="3"]{transition-delay:0.3s;}
[data-reveal-delay="4"]{transition-delay:0.4s;}

/* ── FOOTER ── */
.osb-footer{background:var(--purple-deep);color:rgba(255,255,255,0.65);padding:4rem 5% 2rem;}
.footer-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;padding-bottom:3rem;
  border-bottom:1px solid rgba(255,255,255,0.1);
}
.footer-brand .nav-logo{font-size:1.4rem;margin-bottom:1rem;color:white;}
.footer-brand p{font-size:0.82rem;line-height:1.7;max-width:240px;}
.footer-col h4{font-size:0.68rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--gold-light);margin-bottom:1rem;}
.footer-col a{display:block;font-size:0.82rem;color:rgba(255,255,255,0.5);margin-bottom:0.5rem;transition:color 0.2s;}
.footer-col a:hover{color:white;}
.footer-bottom{
  max-width:1200px;margin:2rem auto 0;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:0.5rem;
  font-size:0.7rem;color:rgba(255,255,255,0.25);
}
.footer-tagline{font-family:'Playfair Display',serif;font-style:italic;font-size:0.82rem;color:rgba(255,255,255,0.35);}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .nav-links{display:none;}.nav-hamburger{display:flex;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:600px){
  .section{padding:4rem 5%;}
  .footer-grid{grid-template-columns:1fr;gap:2rem;}
  .footer-bottom{flex-direction:column;text-align:center;}
}

/* Real product images */
.prod-img-real{width:100%;height:220px;object-fit:cover;display:block;}
