/* =====================================================
   NAILFLOW — Light Feminine Design System
   Aesthetic: Soft Luxury / Blush & Rose Gold
   Fonts: Cormorant Garamond + DM Sans
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,500;0,600;0,700;1,500&family=DM+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --rose:         #e8486a;
  --rose-hover:   #d4304f;
  --rose-deep:    #b91c3c;
  --rose-glow:    rgba(232,72,106,0.18);
  --rose-subtle:  rgba(232,72,106,0.07);
  --rose-border:  rgba(232,72,106,0.20);

  --blush:        #fff0f3;
  --blush-2:      #fde8ed;
  --blush-3:      #fad4dd;

  --gold:         #c9944a;
  --gold-subtle:  rgba(201,148,74,0.10);
  --green:        #16a34a;
  --green-subtle: rgba(22,163,74,0.08);

  --bg-base:      #fef9fb;
  --bg-2:         #fff4f6;
  --bg-card:      #ffffff;

  --text:         #1e0e1a;
  --text-muted:   #7a5c6e;
  --text-faint:   #c4a8b4;

  --border:       #f2dce3;
  --border-card:  #eddde4;

  --sh:      0 4px 16px rgba(180,80,110,0.08);
  --sh-lg:   0 16px 48px rgba(180,80,110,0.13);
  --sh-rose: 0 8px 32px rgba(232,72,106,0.26);
  --sh-card: 0 2px 12px rgba(180,80,110,0.07);

  --ease:        cubic-bezier(0.4,0,0.2,1);
  --ease-out:    cubic-bezier(0,0,0.2,1);
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);

  --t-xs:   0.15s;
  --t-sm:   0.25s;
  --t-base: 0.38s;
  --t-lg:   0.60s;

  --r-sm: 10px;
  --r:    18px;
  --r-lg: 26px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:100%}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--bg-base);color:var(--text);
  line-height:1.65;overflow-x:hidden;
  padding-top:calc(4.5rem + 2.8rem);
}
h1,h2,h3,h4{
  font-family:'Cormorant Garamond',Georgia,serif;
  line-height:1.12;letter-spacing:-0.02em;font-weight:700;color:var(--text);
}
h1{font-size:clamp(2.4rem,5.5vw,4.4rem)}
h2{font-size:clamp(1.9rem,3.8vw,3rem)}
h3{font-size:1.35rem;font-weight:600}
p{line-height:1.7}
a{transition:color var(--t-xs)}

.container{max-width:1120px;margin:0 auto;padding:0 1.5rem}
.section-padding{padding:6rem 0}

/* ─── Section labels ─── */
.section-label{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:var(--rose-subtle);border:1px solid var(--rose-border);
  color:var(--rose);font-size:0.7rem;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;
  padding:0.4rem 1rem;border-radius:50px;margin-bottom:1.25rem;
}
.section-label::before{
  content:'';display:inline-block;width:5px;height:5px;
  background:var(--rose);border-radius:50%;
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.6)}}

.section-title{text-align:center;color:var(--text);margin-bottom:0.6rem}
.section-subtitle{
  text-align:center;color:var(--text-muted);font-size:1.05rem;
  max-width:580px;margin:0 auto 3.5rem;
}

/* ─── Ticker ─── */
.ticker-bar{
  position:fixed;top:0;width:100%;z-index:1001;height:2.8rem;overflow:hidden;
  background:linear-gradient(90deg,var(--rose-deep),var(--rose),var(--rose-deep));
  background-size:200% 100%;animation:ticker-bg 8s linear infinite;
  display:flex;align-items:center;
}
@keyframes ticker-bg{from{background-position:0% 0%}to{background-position:200% 0%}}
.ticker-track{display:flex;animation:ticker-scroll 30s linear infinite;white-space:nowrap;will-change:transform}
.ticker-item{
  display:inline-flex;align-items:center;gap:0.6rem;
  font-size:0.79rem;font-weight:600;letter-spacing:0.04em;color:white;padding:0 3rem;
}
.ticker-sep{color:rgba(255,255,255,0.45)}
@keyframes ticker-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── Navbar ─── */
.navbar{
  position:fixed;top:2.8rem;width:100%;height:4.5rem;z-index:1000;
  display:flex;align-items:center;
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  background:rgba(254,249,251,0.85);
  border-bottom:1px solid var(--border);
  transition:background var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease);
}
.navbar.scrolled{background:rgba(254,249,251,0.97);box-shadow:0 2px 24px rgba(180,80,110,0.10)}
.nav-content{display:flex;justify-content:space-between;align-items:center;width:100%}
.logo{
  font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:700;
  color:var(--text);text-decoration:none;letter-spacing:-0.03em;
  transition:color var(--t-xs);
}
.logo:hover{color:var(--rose)}
.logo span{color:var(--rose)}
.logo-img{height:44px;width:auto;display:block;transition:opacity var(--t-xs)}
.logo:hover .logo-img{opacity:0.85}

/* ─── Buttons ─── */
.btn-primary{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:var(--rose);color:white!important;
  padding:0.75rem 1.75rem;border-radius:50px;
  text-decoration:none;font-weight:700;font-size:0.88rem;
  border:none;cursor:pointer;
  transition:transform var(--t-xs) var(--ease-spring),box-shadow var(--t-sm),background var(--t-xs);
  position:relative;overflow:hidden;white-space:nowrap;
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(255,255,255,0.22) 0%,transparent 60%);
  pointer-events:none;
}
.btn-primary:hover{transform:translateY(-2px) scale(1.03);box-shadow:var(--sh-rose);background:var(--rose-hover)}
.btn-primary:active{transform:scale(0.97);transition-duration:0.08s}
.btn-primary.large{padding:1.1rem 2.6rem;font-size:1rem}

.btn-outline{
  display:inline-flex;align-items:center;gap:0.4rem;
  border:1.5px solid var(--rose-border);color:var(--rose)!important;
  background:transparent;padding:0.75rem 1.75rem;border-radius:50px;
  text-decoration:none;font-weight:700;font-size:0.88rem;cursor:pointer;
  transition:transform var(--t-xs) var(--ease-spring),border-color var(--t-xs),background var(--t-xs);
  text-align:center;
}
.btn-outline:hover{border-color:var(--rose);background:var(--rose-subtle);transform:translateY(-2px)}

/* ─── Proof bar ─── */
.proof-bar{
  background:var(--blush);border-bottom:1px solid var(--border);
  padding:0.85rem 0;text-align:center;font-size:0.86rem;color:var(--text-muted);
}
.proof-bar strong{color:var(--rose)}
.proof-avatars{display:inline-flex;margin-right:0.6rem;vertical-align:middle}
.proof-avatar{
  width:26px;height:26px;border-radius:50%;border:2px solid var(--blush);
  font-size:0.7rem;display:inline-flex;align-items:center;justify-content:center;
  margin-left:-8px;background:linear-gradient(135deg,var(--blush-2),var(--blush));
}
.proof-avatar:first-child{margin-left:0}

/* ─── PRODUCT INTRO ─── */
.product-intro{
  background:white;border-bottom:1px solid var(--border);
  padding:5rem 0;
}
.intro-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;
}
.intro-text .intro-eyebrow{
  display:inline-block;background:var(--rose-subtle);border:1px solid var(--rose-border);
  color:var(--rose);font-size:0.7rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  padding:0.35rem 0.9rem;border-radius:50px;margin-bottom:1.1rem;
}
.intro-text h2{text-align:left;font-size:clamp(1.7rem,3vw,2.5rem);margin-bottom:1rem;line-height:1.15}
.intro-text p{color:var(--text-muted);margin-bottom:0.85rem;font-size:0.97rem}
.intro-text .intro-cta{margin-top:1.75rem}
.intro-steps{display:flex;flex-direction:column;gap:0}
.intro-step{
  display:flex;gap:1.25rem;align-items:flex-start;
  padding:1.4rem 1.5rem;border-radius:var(--r);
  transition:background var(--t-sm);cursor:default;position:relative;
}
.intro-step:hover{background:var(--blush)}
.intro-step-line{
  position:absolute;left:2.75rem;top:5rem;bottom:-0.5rem;
  width:1.5px;background:linear-gradient(to bottom,var(--blush-3),transparent);
}
.intro-step:last-child .intro-step-line{display:none}
.intro-num{
  width:2.75rem;height:2.75rem;min-width:2.75rem;
  background:linear-gradient(135deg,var(--rose),var(--rose-deep));
  color:white;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1rem;
  box-shadow:0 4px 12px rgba(232,72,106,0.28);
  transition:transform var(--t-sm) var(--ease-spring),box-shadow var(--t-sm);
  flex-shrink:0;
}
.intro-step:hover .intro-num{transform:scale(1.08);box-shadow:0 6px 20px rgba(232,72,106,0.38)}
.intro-step-body h4{
  font-family:'DM Sans',sans-serif;font-size:0.97rem;font-weight:700;
  margin-bottom:0.25rem;color:var(--text);letter-spacing:0;
}
.intro-step-body p{font-size:0.86rem;color:var(--text-muted);margin:0;line-height:1.55}

/* NFC Phone demo */
.nfc-demo{position:relative;display:flex;align-items:center;justify-content:center;padding:2rem 0}
.nfc-phone{
  width:200px;height:390px;background:white;
  border-radius:34px;border:6px solid #e8d0d8;
  box-shadow:0 24px 60px rgba(180,80,110,0.16),0 0 0 1px rgba(232,72,106,0.06);
  display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:2;
}
.phone-notch{
  width:68px;height:22px;background:#e8d0d8;
  border-radius:0 0 14px 14px;margin:0 auto;flex-shrink:0;
}
.phone-screen{
  flex:1;background:linear-gradient(160deg,var(--blush) 0%,white 60%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:1.25rem 1rem;gap:0.5rem;
}
.phone-booksy{
  width:90%;height:135px;background:white;
  border-radius:14px;border:1px solid var(--border);
  box-shadow:var(--sh-card);padding:0.75rem;
  display:flex;flex-direction:column;gap:0.4rem;
}
.booksy-bar{height:8px;border-radius:4px;background:var(--blush-2)}
.booksy-bar.accent{background:var(--rose);width:60%}
.booksy-bar.short{width:40%}
.booksy-btn-mock{
  margin-top:auto;background:var(--rose);color:white;
  font-size:0.65rem;font-weight:700;text-align:center;
  padding:0.3rem;border-radius:6px;
}
.phone-nfc-icon{font-size:1.4rem}
.phone-wave-text{
  font-size:0.62rem;color:var(--text-faint);font-weight:600;
  letter-spacing:0.08em;text-transform:uppercase;
}
.nfc-brelok{
  position:absolute;left:-55px;bottom:70px;z-index:3;
  animation:brelok-float 4s ease-in-out infinite;
}
.brelok-shape{
  width:52px;height:88px;
  background:linear-gradient(160deg,#fbc8d4,#f48fa9);
  border-radius:50% 50% 46% 46%/55% 55% 45% 45%;
  box-shadow:0 8px 24px rgba(232,72,106,0.28);
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;
}
@keyframes brelok-float{
  0%,100%{transform:translateY(0) rotate(-6deg)}
  50%{transform:translateY(-14px) rotate(-2deg)}
}
.nfc-waves{
  position:absolute;right:-24px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:6px;z-index:1;
}
.wave{height:2px;background:var(--rose);border-radius:2px;opacity:0;animation:wave-pulse 2s ease-out infinite}
.wave:nth-child(1){width:18px;animation-delay:0s}
.wave:nth-child(2){width:30px;animation-delay:0.25s}
.wave:nth-child(3){width:42px;animation-delay:0.5s}
@keyframes wave-pulse{
  0%{opacity:0;transform:translateX(0)}
  30%{opacity:0.85}
  100%{opacity:0;transform:translateX(10px)}
}

/* ─── Hero ─── */
.hero{
  position:relative;min-height:88vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;padding:5rem 0 4rem;
  background:linear-gradient(160deg,#fff7f9 0%,#fff2f5 40%,var(--blush) 100%);
}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;will-change:transform}
.hero-orb-1{
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(232,72,106,0.12) 0%,transparent 65%);
  top:-180px;right:-100px;animation:orb1 14s ease-in-out infinite alternate;
}
.hero-orb-2{
  width:450px;height:450px;
  background:radial-gradient(circle,rgba(201,148,74,0.09) 0%,transparent 65%);
  bottom:-80px;left:-60px;animation:orb2 18s ease-in-out infinite alternate;
}
.hero-orb-3{
  width:350px;height:350px;
  background:radial-gradient(circle,rgba(232,72,106,0.07) 0%,transparent 65%);
  top:50%;left:50%;transform:translate(-50%,-50%);animation:orb3 22s ease-in-out infinite alternate;
}
@keyframes orb1{from{transform:translate(0,0) scale(1)}to{transform:translate(-60px,40px) scale(1.1)}}
@keyframes orb2{from{transform:translate(0,0) scale(1)}to{transform:translate(50px,-40px) scale(1.15)}}
@keyframes orb3{from{transform:translate(-50%,-50%) scale(1)}to{transform:translate(-50%,-58%) scale(0.9)}}
.hero-grid{
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(232,72,106,0.09) 1px,transparent 1px);
  background-size:44px 44px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 80%);
  pointer-events:none;
}
.hero-floats{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.f{position:absolute;font-size:1.8rem;opacity:0;animation:float-in 1s var(--ease-out) forwards,float-a 8s ease-in-out infinite;will-change:transform}
.f:nth-child(1){top:14%;left:7%;animation-delay:0.8s,0.8s}
.f:nth-child(2){top:22%;right:9%;animation-delay:1.0s,1.0s;animation-name:float-in,float-b;font-size:1.3rem}
.f:nth-child(3){bottom:28%;left:9%;animation-delay:1.2s,1.2s;animation-name:float-in,float-c;font-size:2.2rem}
.f:nth-child(4){top:55%;right:7%;animation-delay:1.4s,1.4s;animation-name:float-in,float-a;font-size:1.1rem}
.f:nth-child(5){bottom:18%;right:18%;animation-delay:1.6s,1.6s;animation-name:float-in,float-b}
@keyframes float-in{from{opacity:0;transform:translateY(20px)}to{opacity:0.18;transform:translateY(0)}}
@keyframes float-a{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-18px) rotate(5deg)}}
@keyframes float-b{0%,100%{transform:translateY(0) rotate(5deg) scale(1)}50%{transform:translateY(-22px) rotate(-3deg) scale(1.05)}}
@keyframes float-c{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-14px) scale(1.08)}}

.hero-content{position:relative;z-index:2}
.hero-tag{
  display:inline-block;background:white;border:1px solid var(--rose-border);
  color:var(--rose);font-size:0.7rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  padding:0.45rem 1.1rem;border-radius:50px;margin-bottom:1.5rem;
  box-shadow:var(--sh-card);animation:anim-up 0.7s 0.2s var(--ease-out) both;
}
.hero h1{color:var(--text);margin-bottom:1.5rem;animation:anim-up 0.7s 0.35s var(--ease-out) both;max-width:820px;margin-left:auto;margin-right:auto}
.hero h1 .accent{color:var(--rose);position:relative;display:inline-block}
.hero h1 .accent::after{
  content:'';position:absolute;bottom:3px;left:0;right:0;height:3px;border-radius:2px;
  background:linear-gradient(90deg,var(--rose),var(--gold));
  transform-origin:left;animation:line-grow 0.8s 1.1s var(--ease-out) both;
}
@keyframes line-grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.hero-sub{font-size:1.12rem;color:var(--text-muted);max-width:540px;margin:0 auto 2.5rem;animation:anim-up 0.7s 0.5s var(--ease-out) both}
.hero-stats{
  display:flex;justify-content:center;align-items:center;
  margin:0 auto 2.5rem;max-width:580px;
  animation:anim-up 0.7s 0.6s var(--ease-out) both;
  background:white;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.25rem 2rem;box-shadow:var(--sh-lg);
}
.hero-stat{flex:1;text-align:center;padding:0 1.25rem}
.hero-stat+.hero-stat{border-left:1px solid var(--border)}
.stat-num{
  display:block;font-family:'Cormorant Garamond',serif;
  font-size:2.5rem;font-weight:700;color:var(--text);line-height:1;margin-bottom:0.2rem;
}
.stat-num .rose{color:var(--rose)}
.stat-num .green{color:var(--green)}
.stat-label{font-size:0.72rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:0.1em}
.hero-cta{animation:anim-up 0.7s 0.75s var(--ease-out) both;margin-bottom:1.25rem}
.hero-trust{font-size:0.8rem;color:var(--text-faint);animation:anim-up 0.7s 0.88s var(--ease-out) both}

/* ─── Scroll reveal ─── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity var(--t-lg) var(--ease-out),transform var(--t-lg) var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}
.rd1{transition-delay:.1s}.rd2{transition-delay:.2s}.rd3{transition-delay:.3s}.rd4{transition-delay:.4s}.rd5{transition-delay:.5s}.rd6{transition-delay:.6s}
@keyframes anim-up{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

/* ─── How it works ─── */
.how-section{background:var(--bg-2)}
.steps-grid{display:grid;grid-template-columns:1fr 56px 1fr 56px 1fr;align-items:start;margin-top:3.5rem}
.step-arrow{display:flex;align-items:center;justify-content:center;padding-top:3rem;color:var(--blush-3);font-size:1.4rem}
.step-card{
  background:white;border:1px solid var(--border-card);border-radius:var(--r);
  padding:2.25rem 1.75rem;text-align:center;box-shadow:var(--sh-card);cursor:default;
  transition:transform var(--t-base) var(--ease-spring),border-color var(--t-sm),box-shadow var(--t-sm);
}
.step-card:hover{transform:translateY(-7px);border-color:var(--rose-border);box-shadow:var(--sh-lg)}
.step-num{
  width:3rem;height:3rem;background:linear-gradient(135deg,var(--rose),var(--rose-deep));
  color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1.1rem;margin:0 auto 1.5rem;
  box-shadow:0 4px 14px rgba(232,72,106,0.28);
  transition:box-shadow var(--t-sm),transform var(--t-sm) var(--ease-spring);
}
.step-card:hover .step-num{box-shadow:0 6px 20px rgba(232,72,106,0.38);transform:scale(1.05)}
.step-card h3{margin-bottom:0.6rem;color:var(--text);font-size:1.15rem}
.step-card p{color:var(--text-muted);font-size:0.88rem}

/* ─── Value section ─── */
.value-section{background:white}
.value-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.value-card{
  background:var(--blush);border:1px solid var(--border);border-radius:var(--r);padding:2rem;cursor:default;
  transition:transform var(--t-base) var(--ease-spring),border-color var(--t-sm),box-shadow var(--t-sm),background var(--t-sm);
}
.value-card:hover{transform:translateY(-5px) scale(1.01);border-color:var(--rose-border);background:white;box-shadow:var(--sh-lg)}
.value-icon{
  width:3rem;height:3rem;background:white;border:1px solid var(--border);border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.1rem;
  box-shadow:var(--sh-card);transition:transform var(--t-sm) var(--ease-spring);
}
.value-card:hover .value-icon{transform:scale(1.08) rotate(-4deg)}
.value-card h3{margin-bottom:0.5rem;color:var(--text);font-size:1.1rem}
.value-card p{color:var(--text-muted);font-size:0.9rem}

/* ─── Gallery ─── */
.gallery-section{background:var(--bg-2)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.gallery-card{
  border-radius:var(--r);overflow:hidden;border:1px solid var(--border);
  background:white;box-shadow:var(--sh-card);
  transition:transform var(--t-base) var(--ease-spring),box-shadow var(--t-sm);
}
.gallery-card:hover{transform:translateY(-8px);box-shadow:var(--sh-lg)}
.gallery-img{height:255px;overflow:hidden;background:var(--blush)}
.gallery-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-lg) var(--ease)}
.gallery-card:hover .gallery-img img{transform:scale(1.07)}
.gallery-body{padding:1.5rem}
.gallery-body h3{font-size:1.05rem;margin-bottom:0.4rem;color:var(--text)}
.gallery-body p{color:var(--text-muted);font-size:0.86rem}

/* ─── Testimonials ─── */
.testimonials-section{background:white}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.testi-card{
  background:var(--blush);border:1px solid var(--border);border-radius:var(--r);
  padding:1.75rem;position:relative;overflow:hidden;cursor:default;
  transition:transform var(--t-base) var(--ease-spring),box-shadow var(--t-sm),background var(--t-sm);
}
.testi-card::before{
  content:'"';position:absolute;top:0;right:1.25rem;
  font-family:'Cormorant Garamond',serif;font-size:7rem;line-height:1;
  color:var(--rose);opacity:0.12;pointer-events:none;
}
.testi-card:hover{transform:translateY(-4px);background:white;box-shadow:var(--sh-lg)}
.stars{color:var(--gold);letter-spacing:2px;margin-bottom:0.75rem;font-size:0.9rem}
.testi-card blockquote{font-style:italic;font-size:0.92rem;color:var(--text-muted);margin-bottom:1.25rem;line-height:1.65;position:relative;z-index:1}
.testi-author strong{display:block;font-size:0.88rem;color:var(--text);margin-bottom:0.1rem}
.testi-author span{font-size:0.78rem;color:var(--text-faint)}

/* ─── Pricing ─── */
.pricing-section{background:var(--bg-2)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.price-card{
  background:white;border:1.5px solid var(--border-card);border-radius:var(--r-lg);
  padding:2.5rem 2rem;text-align:center;
  position:relative;overflow:visible;
  box-shadow:var(--sh-card);
  transition:transform var(--t-base) var(--ease-spring),box-shadow var(--t-sm),border-color var(--t-sm);
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);border-color:var(--rose-border)}
.price-card.popular{
  border-color:var(--rose);border-width:2px;
  box-shadow:var(--sh-rose);transform:translateY(-10px);
  animation:popular-float 5s ease-in-out infinite;
  background:linear-gradient(160deg,#fff7f9,white);
}
.price-card.popular:hover{animation-play-state:paused;transform:translateY(-16px);box-shadow:0 28px 72px rgba(232,72,106,0.28)}
@keyframes popular-float{0%,100%{transform:translateY(-10px)}50%{transform:translateY(-17px)}}
.badge{
  position:absolute;top:-15px;left:50%;transform:translateX(-50%);
  background:linear-gradient(90deg,var(--rose),var(--rose-deep));color:white;
  padding:0.35rem 1.3rem;border-radius:50px;font-size:0.68rem;font-weight:800;
  letter-spacing:0.12em;white-space:nowrap;box-shadow:var(--sh-rose);z-index:10;
}
.price-label{font-size:0.7rem;font-weight:800;letter-spacing:0.18em;text-transform:uppercase;color:var(--rose);margin-bottom:0.4rem}
.price-qty{color:var(--text-muted);font-size:0.88rem;margin-bottom:0.75rem}

/* Promo pricing */
.price-old{font-size:1.1rem;color:var(--text-faint);text-decoration:line-through;display:block;margin-bottom:0}
.price-promo-label{
  display:inline-block;background:#dcfce7;color:var(--green);
  font-size:0.7rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;
  padding:0.2rem 0.65rem;border-radius:50px;margin:0.25rem 0;
}
.price-amount{font-family:'Cormorant Garamond',serif;font-size:3.8rem;font-weight:700;color:var(--text);line-height:1;margin-bottom:0.2rem}
.price-per{font-size:0.76rem;color:var(--text-faint);margin-bottom:1rem}
.price-desc{color:var(--text-muted);font-size:0.88rem;margin-bottom:1rem}
.price-features{list-style:none;text-align:left;display:flex;flex-direction:column;gap:0.5rem;margin:1.25rem 0 2rem}
.price-features li{display:flex;align-items:flex-start;gap:0.6rem;font-size:0.87rem;color:var(--text-muted)}
.price-features li::before{content:'';width:5px;height:5px;min-width:5px;background:var(--rose);border-radius:50%;margin-top:0.55rem}
.price-guarantee{font-size:0.76rem;color:var(--green);font-weight:600;margin-top:0.75rem}

/* ─── Guarantee box ─── */
.guarantee-wrap{max-width:560px;margin:4rem auto 0}
.guarantee-box{
  background:#f0fdf4;border:1.5px solid #86efac;border-radius:var(--r);
  padding:2.25rem 2rem;text-align:center;transition:box-shadow var(--t-sm);
}
.guarantee-box:hover{box-shadow:0 8px 32px rgba(22,163,74,0.10)}
.guarantee-box .g-icon{font-size:2.5rem;display:block;margin-bottom:0.5rem}
.guarantee-box h3{color:#15803d;font-size:1.4rem;margin-bottom:0.5rem}
.guarantee-box p{color:#166534;font-size:0.9rem}

/* ─── FAQ ─── */
.faq-section{background:white}
.faq-wrapper{max-width:740px;margin:0 auto;display:flex;flex-direction:column;gap:0.6rem}
details{
  background:var(--blush);border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;
  transition:border-color var(--t-xs),box-shadow var(--t-xs),background var(--t-xs);
}
details[open]{border-color:var(--rose-border);background:white;box-shadow:var(--sh-card)}
details summary{
  padding:1.2rem 1.5rem;font-weight:600;font-size:0.95rem;cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;color:var(--text);
  transition:color var(--t-xs);
}
details summary::-webkit-details-marker{display:none}
details[open] summary{color:var(--rose)}
.faq-icon{
  width:1.8rem;height:1.8rem;border-radius:50%;
  background:white;border:1px solid var(--rose-border);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;color:var(--rose);flex-shrink:0;margin-left:1rem;
  transition:transform var(--t-base) var(--ease-spring),background var(--t-xs);
}
details[open] summary .faq-icon{transform:rotate(45deg);background:var(--rose-subtle)}
details>div{padding:0 1.5rem 1.3rem;color:var(--text-muted);font-size:0.91rem;line-height:1.7}

/* ─── Contact ─── */
.contact-section{
  background:linear-gradient(160deg,#1e0e1a 0%,#2d1520 100%);
  position:relative;overflow:hidden;
}
.c-orb{
  position:absolute;width:700px;height:700px;top:-300px;left:50%;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(232,72,106,0.10) 0%,transparent 70%);pointer-events:none;
}
.contact-inner{max-width:560px;margin:0 auto;text-align:center;position:relative;z-index:1}
.contact-inner h2{color:white;margin-bottom:0.6rem}
.form-sub{color:rgba(255,255,255,0.6);font-size:0.92rem;margin-bottom:2.5rem}
.form-grid{text-align:left}
.form-row{margin-bottom:0.7rem}
.form-row select,.form-row input{
  width:100%;padding:0.9rem 1.1rem;
  background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-sm);font-size:0.93rem;font-family:inherit;color:white;outline:none;
  -webkit-appearance:none;appearance:none;
  transition:border-color var(--t-xs),background var(--t-xs),box-shadow var(--t-xs);
}
.form-row select option{background:#2d1520;color:white}
.form-row select:focus,.form-row input:focus{
  border-color:rgba(232,72,106,0.5);background:rgba(255,255,255,0.10);
  box-shadow:0 0 0 3px rgba(232,72,106,0.12);
}
.form-row input::placeholder{color:rgba(255,255,255,0.35)}
.form-check{
  display:flex;align-items:flex-start;gap:0.6rem;
  font-size:0.81rem;color:rgba(255,255,255,0.55);margin-bottom:1.2rem;text-align:left;
}
.form-check input[type="checkbox"]{width:1rem;height:1rem;accent-color:var(--rose);margin-top:0.15rem;flex-shrink:0}
.form-check a{color:var(--rose);text-decoration:none}
.form-check a:hover{text-decoration:underline}
.btn-submit{
  width:100%;padding:1.1rem;font-size:1.02rem;font-weight:700;font-family:'DM Sans',sans-serif;
  background:linear-gradient(90deg,var(--rose),var(--rose-hover));color:white;
  border:none;border-radius:50px;cursor:pointer;position:relative;overflow:hidden;
  transition:transform var(--t-xs) var(--ease-spring),box-shadow var(--t-sm);letter-spacing:0.01em;
}
.btn-submit::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(255,255,255,0.15) 0%,transparent 60%);pointer-events:none;
}
.btn-submit:hover{transform:translateY(-2px);box-shadow:var(--sh-rose)}
.btn-submit:active{transform:scale(0.99)}
.form-trust{margin-top:1rem;font-size:0.76rem;color:rgba(255,255,255,0.3)}

/* ─── Footer ─── */
.footer{padding:2.5rem 0;border-top:1px solid var(--border);background:white}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:0.75rem}
.footer-copy{font-size:0.8rem;color:var(--text-faint)}
.footer-links{display:flex;gap:0.15rem}
.footer-links a{
  font-size:0.8rem;color:var(--text-faint);text-decoration:none;
  padding:0.3rem 0.7rem;border-radius:8px;
  transition:color var(--t-xs),background var(--t-xs);
}
.footer-links a:hover{color:var(--rose);background:var(--rose-subtle)}

/* ─── Responsive ─── */
@media(max-width:960px){
  .steps-grid{grid-template-columns:1fr}.step-arrow{display:none}
  .value-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .price-card.popular{transform:none;animation:none}
  .intro-grid{grid-template-columns:1fr;gap:2.5rem}
  .nfc-demo{display:none}
}
@media(max-width:600px){
  .gallery-grid{grid-template-columns:1fr}
  .hero-stats{flex-direction:column}
  .hero-stat+.hero-stat{border-left:none;border-top:1px solid var(--border)}
  .hero-stat{padding:0.8rem 0}
  .section-padding{padding:4.5rem 0}
  h1{font-size:2.2rem}
}
