@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=Playfair+Display:wght@600;700&display=swap');

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

body {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  line-height: 1.6;
  color: #2b2b2b;
  background: #fff;
  -webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4,h5,h6 { font-family: 'Playfair Display', serif; }
h1 { font-size: 2.8rem; font-weight: 700; line-height: 1.15; }
h2 { font-size: 34px; font-weight: 700; line-height: 1.25; }
h3 { font-size: 1.45rem; font-weight: 600; line-height: 1.35; }
h4 { font-size: 17px; font-weight: 500; line-height: 1.5; }

img { max-width: 100%; height: auto; }
a { color: #e94560; text-decoration: none; transition: color 0.3s; }
a:hover { color: #ff6b6b; text-decoration: none; }
.container { max-width: 1170px; margin: 0 auto; padding: 0 15px; }

.sec-heading { text-align: center; font-size: 1.55rem; text-transform: uppercase; letter-spacing: 3.5px; margin-bottom: 28px; }
.section-intro { text-align: center; color: #666; max-width: 680px; margin: -8px auto 36px; font-size: 14.5px; line-height: 1.7; }


#topbar { background: #141425; color: #fff; padding: 9px 0; font-size: 12.5px; }
.tb-inner { max-width: 1170px; margin: 0 auto; padding: 0 15px; display: flex; justify-content: space-between; align-items: center; }
.usp-row { display: flex; align-items: center; gap: 28px; }
.usp-item { color: #fff; white-space: nowrap; }
.usp-item i { margin-right: 6px; }


#hdr-main { background: #fff; border-bottom: 1px solid #efefef; }
.hdr-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 15px; }
.hdr-left { display: flex; align-items: center; flex:1; }
.hdr-center { text-align: center; flex: 1; }
.hdr-right { flex: 1; display: flex; justify-content: flex-end; }
.hdr-center img { max-height: 58px; width: auto; }

#mobilenav { cursor: pointer; display: flex; flex-direction: column; gap: 5px; margin-right: 14px; }
.burger-bar { display: block; width: 24px; height: 2.5px; background: #2b2b2b; border-radius: 2px; transition: .35s; }
#mobilenav.open .burger-bar:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
#mobilenav.open .burger-bar:nth-child(2){opacity:0}
#mobilenav.open .burger-bar:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}


.cart-btn { position: relative; display: inline-block; }
.cart-qty { position: absolute; top: -7px; right: -9px; background: #e94560; color: #fff; border-radius: 50%; width: 19px; height: 19px; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; }

#mainnav { background: #fff; border-bottom: 1px solid #efefef; }
.nav-list { list-style: none; display: flex; justify-content: center; padding: 0; margin: 0; }
.nav-list > li { margin: 0 22px; }
.nav-list > li > a { display: block; padding: 14px 0; color: #2b2b2b; font-family: 'DM Sans', sans-serif; font-size: 13.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .7px; transition: color .3s; }
.nav-list > li > a:hover, .nav-list > li.active > a { color: #e94560; }

#mob-menu { background: #fff; border-bottom: 1px solid #efefef; }
#mob-menu ul { list-style: none; padding: 8px 20px 4px; }
#mob-menu li { border-bottom: 1px solid #f4f4f4; }
#mob-menu a { display: block; padding: 11px 0; color: #2b2b2b; font-size: 14.5px; font-weight: 500; text-transform: uppercase; letter-spacing: .5px; }
#mob-menu a:hover { color: #e94560; }

.hero-banners { overflow: hidden; }
.hero-grid { display: flex; }
.hero-item { flex: 1; position: relative; min-height: 340px; background-size: cover; background-position: center; overflow: hidden; }
.hero-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.32); transition: background .4s; }
.hero-item:hover .hero-overlay { background: rgba(0,0,0,.42); }
.hero-txt { text-align: center; color: #fff; }
.hero-txt h2 { font-size: 2rem; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 1.5px; color: #fff; }
.hero-txt p { font-size: 1.05rem; margin-bottom: 18px; color: rgba(255,255,255,.9); }

.btn-main { display: inline-block; background: #e94560; color: #fff; padding: 11px 28px; border-radius: 24px; text-transform: uppercase; font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 13px; letter-spacing: .8px; transition: all .3s; border: none; cursor: pointer; }
.btn-main:hover { background: #ff6b6b; transform: translateY(-2px); color: #fff; }
.btn-outline { display: inline-block; background: transparent; color: #2b2b2b; padding: 10px 24px; border-radius: 24px; font-family: 'DM Sans', sans-serif; font-weight: 600; font-size: 12.5px; letter-spacing: .5px; border: 1.5px solid #ddd; cursor: pointer; transition: all .25s; }
.btn-outline:hover { border-color: #e94560; color: #e94560; }


.about-block { padding: 62px 0 48px; }
.about-row { display: flex; gap: 44px; align-items: flex-start; }
.about-img-col { flex: 0 0 420px; }
.about-img-col img:first-child { width: 100%; border-radius: 8px; margin-bottom: 14px; }
.about-img-sm { width: 60%; border-radius: 6px; }
.about-txt-col { flex: 1; }
.about-txt-col h3 { font-size: 1.55rem; text-transform: uppercase; letter-spacing: 2.5px; margin-bottom: 18px; }
.about-txt-col p { font-size: 14px; color: #555; line-height: 1.75; margin-bottom: 14px; }


#prodSection { padding: 55px 0 36px; background: #fafafa; }
.prod-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.pCard { position: relative; background: #fff; transition: box-shadow .3s; border-radius: 6px; overflow: hidden; }
.pCard:hover { box-shadow: 0 6px 24px rgba(0,0,0,.09); }
.pCard-badge { position: absolute; top: 10px; left: 10px; background: #e94560; color: #fff; padding: 4px 11px; border-radius: 3px; font-size: 11.5px; font-weight: 700; z-index: 2; font-family: 'DM Sans', sans-serif; }
.pCard-img { position: relative; overflow: hidden; }
.pCard-img img { width: 100%; display: block; transition: transform .35s; }
.pCard:hover .pCard-img img { transform: scale(1.05); }
.pCard h4 { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 600; margin: 14px 14px 6px; line-height: 1.4; }
.pCard h4 a { color: #2b2b2b; }
.pCard h4 a:hover { color: #e94560; }
.pCard-desc { font-size: 12.5px; color: #777; line-height: 1.6; margin: 0 14px 10px; }
.pCard-price { font-size: 15px; font-weight: 700; color: #2b2b2b; font-family: 'DM Sans', sans-serif; padding: 0 14px 12px; }
.old-price { text-decoration: line-through; color: #aaa; margin-right: 8px; font-weight: 400; }
.pCard-atc { width: calc(100% - 28px); margin: 0 14px 14px; padding: 9px 0; font-size: 12px; text-align: center; display: block; }


.process-section { padding: 60px 0 44px; }
.process-grid { display: flex; gap: 36px; margin-top: 10px; }
.process-step { flex: 1; text-align: center; position: relative; }
.step-circle { width: 52px; height: 52px; border-radius: 50%; background: #e94560; color: #fff; font-family: 'Playfair Display', serif; font-size: 1.35rem; font-weight: 700; display: flex; align-items: center; justify-content: center; margin: 0 auto 18px; position: relative; z-index: 1; }
.step-img { width: 100%; height: 160px; object-fit: cover; border-radius: 6px; margin-bottom: 16px; }
.process-step h4 { font-family: 'Playfair Display', serif; font-size: 17px; font-weight: 600; margin-bottom: 10px; }
.process-step p { font-size: 13.5px; color: #555; line-height: 1.65; text-align: left; }
.process-step::after { content: ''; position: absolute; top: 26px; left: calc(50% + 32px); width: calc(100% - 64px); height: 2px; background: #eee; z-index: 0; }
.process-step:last-child::after { display: none; }


.team-section { padding: 52px 0 48px; background: #fafafa; }
.team-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; }
.team-card { background: #fff; border-radius: 8px; padding: 32px 28px; transition: box-shadow .3s; }
.team-card:hover { box-shadow: 0 6px 22px rgba(0,0,0,.07); }
.team-icon { width: 56px; height: 56px; border-radius: 50%; background: rgba(233,69,96,.08); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.team-icon i { font-size: 24px; color: #e94560; }
.team-card h4 { font-family: 'Playfair Display', serif; font-size: 1.15rem; font-weight: 700; margin-bottom: 4px; }
.team-role { font-size: 12.5px; font-weight: 600; color: #e94560; text-transform: uppercase; letter-spacing: .6px; margin-bottom: 14px; }
.team-card p { font-size: 13.5px; color: #555; line-height: 1.7; }


.services-section { padding: 56px 0 44px; }
.services-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.srv-card { background: #fff; border: 1px solid #f0f0f0; border-radius: 8px; padding: 28px 24px; transition: box-shadow .3s, border-color .3s; overflow: hidden; }
.srv-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.06); border-color: #e94560; }
.srv-top { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.srv-icon { width: 48px; height: 48px; border-radius: 12px; background: #e94560; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.srv-icon i { font-size: 20px; color: #fff; }
.srv-card h4 { font-family: 'Playfair Display', serif; font-size: 16px; font-weight: 600; }
.srv-card p { font-size: 13.5px; color: #555; line-height: 1.65; margin-bottom: 16px; }
.srv-img { width: 100%; height: 140px; object-fit: cover; border-radius: 5px; }


.faq-section { padding: 56px 0 48px; background: #fafafa; }
.faq-list { max-width: 780px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid #e8e8e8; }
.faq-q { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; cursor: pointer; gap: 16px; }
.faq-q span { font-family: 'DM Sans', sans-serif; font-size: 15px; font-weight: 600; color: #2b2b2b; }
.faq-q i { font-size: 16px; color: #999; transition: transform .3s; flex-shrink: 0; }
.faq-item.open .faq-q i { color: #e94560; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.faq-a p { padding: 0 0 18px; font-size: 14px; color: #666; line-height: 1.7; }


.contact-section { padding: 56px 0 52px; }
.contact-row { display: flex; gap: 40px; }
.contact-info-col { flex: 0 0 320px; }
.contact-form-col { flex: 1; }
.ci-block { display: flex; gap: 14px; margin-bottom: 22px; align-items: flex-start; }
.ci-block > i { font-size: 20px; color: #e94560; margin-top: 2px; }
.ci-block strong { display: block; font-size: 14px; font-weight: 700; margin-bottom: 2px; }
.ci-block p { font-size: 13.5px; color: #666; }
.ci-block a { color: #666; }
.ci-block a:hover { color: #e94560; }
.form-grp { margin-bottom: 14px; }
.form-grp input, .form-grp textarea { width: 100%; padding: 12px 16px; border: 1px solid #ddd; border-radius: 6px; font-size: 14px; font-family: 'DM Sans', sans-serif; outline: none; transition: border-color .25s; }
.form-grp input:focus, .form-grp textarea:focus { border-color: #e94560; }
.form-grp textarea { resize: vertical; }
.form-row-2col { display: flex; gap: 14px; }
.form-row-2col .form-grp { flex: 1; }


.ftr-main { background: #141425; color: #fff; padding: 56px 0 34px; }

.ftr-cols { display: flex; gap: 40px; flex-wrap: wrap; }
.ftr-col { flex: 1; min-width: 200px; }
.ftr-about { flex: 1.5; }
.ftr-logo { max-width: 180px; margin-bottom: 16px; filter: brightness(0) invert(1);}
.ftr-desc { color: rgba(255,255,255,.65); margin-bottom: 14px; font-size: 14px; }
.ftr-info { color: rgba(255,255,255,.65); font-size: 13.5px; margin-bottom: 9px; }
.ftr-info i { margin-right: 7px; width: 18px; display: inline-block; }
.ftr-info a { color: rgba(255,255,255,.65); }
.ftr-info a:hover { color: #e94560; }
.ftr-col h4 { font-size: 17px; font-weight: 600; margin-bottom: 18px; color: #fff; }
.ftr-col ul { list-style: none; padding: 0; }
.ftr-col ul li { margin-bottom: 9px; }
.ftr-col ul a { color: rgba(255,255,255,.65); font-size: 13.5px; transition: color .25s; }
.ftr-col ul a:hover { color: #e94560; }

.cpy-bar { background: #0d0d1a; color: rgba(255,255,255,.45); text-align: center; padding: 18px 0; font-size: 12.5px; }


.cartOvr { position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 9999; display: none; justify-content: center; align-items: flex-start; padding-top: 40px; }
.cartOvr.open { display: flex; }
.cartPopup { background: #fff; width: 90%; max-width: 860px; border-radius: 10px; max-height: 85vh; display: flex; flex-direction: column; overflow: hidden; }
.cartPopup-hdr { display: flex; justify-content: space-between; align-items: center; padding: 18px 24px; border-bottom: 1px solid #eee; }
.cartPopup-hdr h3 { font-size: 1.2rem; color: #2b2b2b; }
.cartClose-btn { background: none; border: none; cursor: pointer; font-size: 20px; color: #666; transition: color .2s; }
.cartClose-btn:hover { color: #e94560; }
.cartPopup-body { flex: 1; overflow-y: auto; padding: 24px; }
.cart-empty-msg { text-align: center; color: #999; padding: 40px 0; font-size: 15px; }
.cartItems-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.cartItem-card { background: #fafafa; border-radius: 8px; padding: 14px; position: relative; text-align: center; }
.cartItem-card img { width: 100%; height: 120px; object-fit: cover; border-radius: 5px; margin-bottom: 10px; }
.cartItem-info h4 { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 600; margin-bottom: 6px; line-height: 1.3; }
.cartItem-price { font-size: 14px; font-weight: 700; color: #e94560; margin-bottom: 8px; }
.cartItem-qty { display: flex; align-items: center; justify-content: center; gap: 10px; }
.qBtn { width: 28px; height: 28px; border-radius: 50%; border: 1px solid #ddd; background: #fff; cursor: pointer; font-size: 14px; font-weight: 700; transition: all .2s; display: flex; align-items: center; justify-content: center; }
.qBtn:hover { border-color: #e94560; color: #e94560; }
.cartItem-qty span { font-weight: 700; font-size: 14px; min-width: 20px; text-align: center; }
.cartItem-rm { position: absolute; top: 8px; right: 8px; background: none; border: none; cursor: pointer; color: #bbb; font-size: 16px; transition: color .2s; }
.cartItem-rm:hover { color: #e94560; }
.cartPopup-ftr { padding: 18px 24px; border-top: 1px solid #eee; }
.cart-total-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; font-size: 16px; }
.cart-total-row strong { font-size: 1.2rem; color: #e94560; }
.cart-actions { display: flex; gap: 12px; }
.cart-actions .btn-outline { flex: 1; text-align: center; }
.cart-actions .btn-main { flex: 1; text-align: center; }
.orderPopup { background: #fff; width: 90%; max-width: 480px; border-radius: 10px; overflow: hidden; }
.orderPopup-body { padding: 24px; }
.tyModal { position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 10001; display: none; justify-content: center; align-items: center; }
.tyModal.open { display: flex; }
.tyInner { background: #fff; border-radius: 12px; padding: 44px 36px; text-align: center; max-width: 400px; width: 90%; }
.tyInner h3 { margin: 14px 0 8px; font-size: 1.4rem; }
.tyInner p { color: #666; font-size: 14px; margin-bottom: 22px; }

.gdpr-bar { position: fixed; bottom: 0; left: 0; width: 480px; max-width: 100%; background: #fff; box-shadow: 0 -4px 24px rgba(0,0,0,.12); z-index: 9998; border-radius: 0 12px 0 0; display: none; }
.gdpr-bar.show { display: block; }
.gdpr-inner { padding: 22px 24px 16px; }
.gdpr-txt { display: flex; align-items: flex-start; margin-bottom: 14px; }
.gdpr-txt p { font-size: 12.5px; color: #555; line-height: 1.6; }
.gdpr-txt a { color: #e94560; text-decoration: underline; }
.gdpr-btns { display: flex; gap: 10px; }
.gdpr-set-btn { background: none; border: 1.5px solid #ddd; border-radius: 20px; padding: 7px 16px; font-size: 12px; cursor: pointer; font-family: 'DM Sans', sans-serif; font-weight: 600; color: #666; transition: all .2s; }
.gdpr-set-btn:hover { border-color: #e94560; color: #e94560; }
.gdpr-dec-btn { background: none; border: 1.5px solid #ddd; border-radius: 20px; padding: 7px 16px; font-size: 12px; cursor: pointer; font-family: 'DM Sans', sans-serif; font-weight: 600; color: #666; transition: all .2s; }
.gdpr-dec-btn:hover { border-color: #e94560; color: #e94560; }
.gdpr-acc-btn { padding: 7px 20px; font-size: 12px; }
.gdpr-settings-panel { padding: 0 24px 18px; }
.gdpr-opt { margin-bottom: 8px; font-size: 13px; color: #444; }
.gdpr-opt label { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.gdpr-opt input[type="checkbox"] { accent-color: #e94560; width: 16px; height: 16px; }


.pg-banner { position: relative; min-height: 220px; background-size: cover; background-position: center; }
.pg-banner-ov { position: absolute; inset: 0; background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center; }
.pg-banner-ov h1 { color: #fff; font-size: 2.2rem; text-transform: uppercase; letter-spacing: 3px; text-align: center; }

.legal-content { padding: 50px 0 60px; }
.legal-block { max-width: 800px; margin: 0 auto; }
.legal-block h3 { font-size: 1.15rem; margin: 28px 0 10px; color: #2b2b2b; }
.legal-block p { font-size: 14px; color: #555; line-height: 1.75; margin-bottom: 12px; }
.legal-block a { color: #e94560; }

.inner-section { padding: 52px 0; }
.inner-section.alt-bg { background: #fafafa; }
.txt-img-row { display: flex; gap: 38px; align-items: center; }
.txt-img-row.reverse { flex-direction: row-reverse; }
.txt-col { flex: 1; }
.txt-col h3 { font-size: 1.4rem; margin-bottom: 16px; }
.txt-col p { font-size: 14px; color: #555; line-height: 1.75; margin-bottom: 13px; }
.img-col { flex: 0 0 380px; }
.img-col img { width: 100%; border-radius: 7px; display: block; }


.hide-mobile{}
.hide-tablet{}
.show-under992{display:none}
.show-under480{display:none}
.hide-under992{}
.hide-under480{}

@media(max-width:991px){
  .hide-under992{display:none !important}
  .show-under992{display:flex !important}
  .hide-tablet{display:none !important}
  .hero-grid{flex-direction:column}
  .hero-item{min-height:240px}
  .about-row{flex-direction:column;gap:28px}
  .about-img-col{flex:none;max-width:100%}
  .prod-grid{grid-template-columns:repeat(3,1fr);gap:18px}
  .process-grid{flex-direction:column;gap:28px}
  .process-step::after{display:none}
  .step-img{height:140px}
  .team-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .contact-row{flex-direction:column;gap:28px}
  .contact-info-col{flex:none;width:100%}
  .ftr-cols{gap:28px}
  .txt-img-row{flex-direction:column;gap:24px}
  .txt-img-row.reverse{flex-direction:column}
  .img-col{flex:none;max-width:100%}
  .cartItems-grid{grid-template-columns:repeat(2,1fr)}
  .pg-banner{min-height:180px}
  .pg-banner-ov h1{font-size:1.7rem;letter-spacing:2px}
}

@media(max-width:767px){
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .hero-txt h2{font-size:1.5rem}
  .sec-heading{font-size:1.2rem;letter-spacing:2px}

  .ftr-cols{flex-direction:column;gap:24px}
  .ftr-about{flex:1}
  .form-row-2col{flex-direction:column;gap:0}
  .srv-img{height:110px}
  .step-img{height:120px}
  .gdpr-bar{width:100%;border-radius:0}
}

@media(max-width:479px){
  .show-under480{display:block !important}
  .hide-under480{display:none !important}
  .hide-mobile{display:none !important}
  .hdr-center img{max-height:38px}
  .hero-item{min-height:200px}
  .hero-txt h2{font-size:1.2rem;letter-spacing:1px}
  .hero-txt p{font-size:.9rem}
  .btn-main{padding:9px 20px;font-size:11.5px}
  .pCard h4{font-size:12.5px}
  .pCard-price{font-size:13px}
  .pCard-desc{font-size:11.5px;margin:0 10px 8px}
  .pCard-atc{width:calc(100% - 20px);margin:0 10px 10px;font-size:11px;padding:8px 0}
  .usp-row{gap:14px}
  .usp-item{font-size:11px}
  .cartItems-grid{grid-template-columns:1fr}
  .pg-banner{min-height:140px}
  .pg-banner-ov h1{font-size:1.3rem;letter-spacing:1px}
  .gdpr-btns{flex-wrap:wrap}
  .step-img{height:100px}
  .srv-img{height:90px}
}
