/* **********************************************************
   ANIMATED PHONE MOCKUP -- Mobile App Section
   Premium iPhone-style frame . Live screen . Notifications
********************************************************** */

/*  Section layout fix  */
/* Override global col-visual:display:none for this section */
#mobile-app .col-visual{
  display:flex !important;
  align-items:center;
  justify-content:center;
}
#mobile-app .two-col-grid{
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:48px;
}
@media(max-width:900px){
  #mobile-app .two-col-grid{
    grid-template-columns:1fr;
  }
  #mobile-app .col-visual{
    display:flex !important;
    justify-content:center;
    margin-top:24px;
  }
}

/*  Outer wrapper  */
.phone-wrap{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  padding:48px 60px;
  width:100%;
}

/*  Ambient glow behind phone  */
.phone-wrap::before{
  content:'';
  position:absolute;
  width:260px;height:380px;
  border-radius:50%;
  background:radial-gradient(ellipse,rgba(124,58,237,.35) 0%,rgba(0,229,255,.12) 50%,transparent 75%);
  filter:blur(48px);
  animation:phoneGlow 5s ease-in-out infinite;
  pointer-events:none;
  z-index:0;
}
@keyframes phoneGlow{
  0%,100%{transform:scale(1);opacity:.8}
  50%{transform:scale(1.1);opacity:1}
}

/*  Phone frame  */
.phone-frame{
  position:relative;z-index:1;
  width:230px;
  background:linear-gradient(160deg,#1c1230 0%,#0d0820 100%);
  border-radius:44px;
  padding:14px 10px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.12),
    0 0 0 2px rgba(124,58,237,.25),
    0 32px 80px rgba(0,0,0,.7),
    0 0 60px rgba(124,58,237,.2),
    inset 0 1px 0 rgba(255,255,255,.08);
  animation:phoneFloat 6s ease-in-out infinite;
  will-change:transform;
}
@keyframes phoneFloat{
  0%,100%{transform:translateY(0) rotate(-1.5deg)}
  50%{transform:translateY(-12px) rotate(1.5deg)}
}

/* Side buttons */
.phone-frame::before{
  content:'';
  position:absolute;
  right:-3px;top:80px;
  width:3px;height:50px;
  background:linear-gradient(to bottom,rgba(255,255,255,.08),rgba(255,255,255,.15),rgba(255,255,255,.08));
  border-radius:0 2px 2px 0;
}
.phone-frame::after{
  content:'';
  position:absolute;
  left:-3px;top:68px;
  width:3px;height:32px;
  background:linear-gradient(to bottom,rgba(255,255,255,.08),rgba(255,255,255,.12),rgba(255,255,255,.08));
  border-radius:2px 0 0 2px;
  box-shadow:0 42px 0 rgba(255,255,255,.07);
}

/*  Screen  */
.phone-screen-inner{
  background:linear-gradient(160deg,#0f0824 0%,#080415 100%);
  border-radius:34px;
  overflow:hidden;
  position:relative;
  height:440px;
}

.phone-screen-inner::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:30%;
  background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,transparent 100%);
  border-radius:34px 34px 0 0;
  pointer-events:none;z-index:10;
}

/*  Dynamic Island  */
.phone-island{
  width:88px;height:28px;
  background:#000;
  border-radius:14px;
  margin:0 auto 10px;
  position:relative;z-index:5;
  box-shadow:0 0 12px rgba(0,0,0,.8);
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.phone-island-dot{
  width:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle,#1a1a1a 60%,#333 100%);
}
.phone-island-line{
  width:28px;height:4px;border-radius:2px;
  background:radial-gradient(circle at center,#1a1a1a,#222);
}

/*  Status bar  */
.phone-status{
  display:flex;justify-content:space-between;align-items:center;
  padding:0 16px 8px;
  font-size:.58rem;font-weight:700;color:rgba(255,255,255,.7);
  letter-spacing:.04em;
}
.phone-time{ font-size:.7rem;font-weight:800;color:#fff }
.phone-icons{ display:flex;gap:4px;align-items:center }

/*  App header  */
.phone-app-header{
  padding:4px 16px 10px;
  display:flex;align-items:center;justify-content:space-between;
}
.phone-app-logo{
  display:flex;align-items:center;gap:7px;
}
.phone-app-mark{
  width:28px;height:28px;border-radius:8px;
  background:linear-gradient(135deg,var(--violet),var(--blue));
  display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:800;color:#fff;
  box-shadow:0 4px 12px rgba(124,58,237,.5);
}
.phone-app-name{font-size:.7rem;font-weight:700;color:#fff}
.phone-notif-badge{
  width:20px;height:20px;border-radius:50%;
  background:var(--pink);
  display:flex;align-items:center;justify-content:center;
  font-size:.55rem;font-weight:800;color:#fff;
  animation:badgePulse 2s ease-in-out infinite;
}
@keyframes badgePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(247,37,133,.6)}
  50%{box-shadow:0 0 0 5px rgba(247,37,133,0)}
}

/*  Stats row  */
.phone-stats-row{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:6px;padding:0 12px 10px;
}
.phone-stat-box{
  background:rgba(124,58,237,.1);
  border:1px solid rgba(124,58,237,.2);
  border-radius:10px;padding:8px 6px;text-align:center;
}
.phone-stat-val{
  font-family:var(--fh);font-size:.85rem;font-weight:700;
  background:linear-gradient(135deg,var(--violet-lt),var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;line-height:1;
}
.phone-stat-lbl{font-size:.48rem;color:#c0bada;margin-top:3px;letter-spacing:.03em}

/*  Mini bar chart  */
.phone-chart{
  padding:0 12px 10px;
  display:flex;align-items:flex-end;gap:4px;
  height:44px;
}
.phone-chart-bar{
  flex:1;border-radius:3px 3px 0 0;
  background:linear-gradient(to top,var(--violet),var(--cyan));
  opacity:.8;
  animation:chartGrow .8s ease both;
}
.phone-chart-bar:nth-child(1){height:40%;animation-delay:.05s}
.phone-chart-bar:nth-child(2){height:65%;animation-delay:.1s}
.phone-chart-bar:nth-child(3){height:50%;animation-delay:.15s}
.phone-chart-bar:nth-child(4){height:85%;animation-delay:.2s}
.phone-chart-bar:nth-child(5){height:60%;animation-delay:.25s}
.phone-chart-bar:nth-child(6){height:95%;animation-delay:.3s}
.phone-chart-bar:nth-child(7){height:72%;animation-delay:.35s}
@keyframes chartGrow{from{transform:scaleY(0);transform-origin:bottom}}

/*  Live notifications  */
.phone-notifs{
  padding:0 10px;
  display:flex;flex-direction:column;gap:6px;
}
.phone-notif-item{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.07);
  border-radius:12px;padding:8px 10px;
  animation:notifSlideIn .5s ease both;
  position:relative;overflow:hidden;
}
.phone-notif-item::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:3px;
  border-radius:3px 0 0 3px;
}
.phone-notif-item.n-hot::before{background:var(--pink)}
.phone-notif-item.n-new::before{background:var(--cyan)}
.phone-notif-item.n-paid::before{background:var(--green)}
.phone-notif-item.n-alert::before{background:var(--orange)}

.phone-notif-item:nth-child(1){animation-delay:.3s}
.phone-notif-item:nth-child(2){animation-delay:.9s}
.phone-notif-item:nth-child(3){animation-delay:1.5s}
.phone-notif-item:nth-child(4){animation-delay:2.1s}
@keyframes notifSlideIn{
  from{opacity:0;transform:translateX(20px)}
  to{opacity:1;transform:translateX(0)}
}

.phone-notif-icon{
  width:26px;height:26px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;
}
.phone-notif-icon.ic-hot{background:rgba(247,37,133,.2)}
.phone-notif-icon.ic-new{background:rgba(0,229,255,.15)}
.phone-notif-icon.ic-paid{background:rgba(6,214,160,.15)}
.phone-notif-icon.ic-alert{background:rgba(255,107,53,.15)}

.phone-notif-text{flex:1}
.phone-notif-title{font-size:.62rem;font-weight:700;color:var(--white);line-height:1.2}
.phone-notif-sub{font-size:.55rem;color:#c0bada;margin-top:1px}
.phone-notif-time{font-size:.5rem;color:#c0bada;flex-shrink:0}

/*  Floating badges around phone  */
.phone-float-badge{
  position:absolute;
  background:rgba(10,7,28,.95);
  border-radius:12px;padding:8px 12px;
  backdrop-filter:blur(16px);
  border:1px solid rgba(124,58,237,.3);
  box-shadow:0 8px 24px rgba(0,0,0,.5);
  z-index:5;white-space:nowrap;
}
.phone-float-badge.pfb-1{
  top:8%;right:-10px;
  animation:pfbFloat1 5s ease-in-out infinite;
}
.phone-float-badge.pfb-2{
  bottom:18%;left:-10px;
  animation:pfbFloat2 6s ease-in-out infinite;
}
.phone-float-badge.pfb-3{
  top:52%;right:-10px;
  animation:pfbFloat1 7s 1s ease-in-out infinite;
}
@keyframes pfbFloat1{
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-8px) rotate(1deg)}
}
@keyframes pfbFloat2{
  0%,100%{transform:translateY(0) rotate(1deg)}
  50%{transform:translateY(-6px) rotate(-1deg)}
}
.pfb-val{font-family:var(--fh);font-size:.88rem;font-weight:700;line-height:1}
.pfb-lbl{font-size:.55rem;color:#c0bada;margin-top:2px}

/*  Live ping dot  */
.phone-live-dot{
  position:absolute;top:10%;left:0;z-index:6;
  display:flex;align-items:center;gap:5px;
  background:rgba(6,214,160,.12);
  border:1px solid rgba(6,214,160,.3);
  border-radius:20px;padding:4px 9px;
}
.phone-live-dot span:first-child{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px var(--green);
  animation:blink 1.5s infinite;
}
.phone-live-dot span:last-child{
  font-size:.52rem;font-weight:700;color:var(--green);letter-spacing:.05em;
}

/* **********************************************************
   APP STORE BUTTONS -- Premium animated CSS buttons
********************************************************** */
.app-store-row{
  display:flex;gap:14px;flex-wrap:wrap;
  margin-top:4px;
}

/* Remove old image button styles */
.app-store-btn{
  all:unset;
}

/* New premium button */
.store-btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:11px 20px;
  border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  cursor:pointer;
  transition:all .35s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;isolation:isolate;
  text-decoration:none;
  min-width:148px;
}
.store-btn::before{
  content:'';
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(67,97,238,.12));
  opacity:0;
  transition:opacity .35s ease;
}
.store-btn::after{
  content:'';
  position:absolute;z-index:-1;
  top:0;left:-100%;
  width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent);
  transition:left .6s ease;
}
.store-btn:hover{
  border-color:rgba(124,58,237,.5);
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(124,58,237,.3),0 0 0 1px rgba(124,58,237,.2);
}
.store-btn:hover::before{opacity:1}
.store-btn:hover::after{left:150%}
.store-btn:active{transform:translateY(-1px)}

/* Icon */
.store-btn-icon{
  flex-shrink:0;
  width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;
}
.store-btn-icon svg{
  width:24px;height:24px;
  fill:var(--white);
  transition:transform .3s ease;
}
.store-btn:hover .store-btn-icon svg{
  transform:scale(1.12);
}

/* Text */
.store-btn-text{
  position:relative;z-index:1;
  display:flex;flex-direction:column;
  line-height:1.1;
}
.store-btn-text small{
  font-size:.58rem;
  font-weight:500;
  color:rgba(240,238,255,.6);
  letter-spacing:.04em;
  text-transform:uppercase;
}
.store-btn-text strong{
  font-size:.92rem;
  font-weight:700;
  color:var(--white);
  letter-spacing:-.01em;
  font-family:var(--fh);
}

/* Animated bottom border */
.store-btn-border{
  position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--violet),var(--cyan),var(--pink));
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s ease;
  border-radius:0 0 14px 14px;
}
.store-btn:hover .store-btn-border{transform:scaleX(1)}

/* iOS button specific */
.store-btn.btn-ios .store-btn-icon svg{fill:#fff}
.store-btn.btn-ios:hover{
  box-shadow:0 12px 32px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.15);
  border-color:rgba(255,255,255,.25);
}

/* Android button specific */
.store-btn.btn-android .store-btn-icon svg{fill:#01875f}
.store-btn.btn-android:hover{
  box-shadow:0 12px 32px rgba(1,135,95,.25),0 0 0 1px rgba(1,135,95,.2);
  border-color:rgba(1,135,95,.35);
}
.store-btn.btn-android .store-btn-border{
  background:linear-gradient(90deg,#01875f,#4285f4,#34a853,#fbbc05);
}

/* Download count badge */
.store-btn-badge{
  position:absolute;top:-8px;right:-8px;
  background:var(--violet);
  color:#fff;font-size:.5rem;font-weight:800;
  padding:2px 6px;border-radius:20px;
  letter-spacing:.04em;text-transform:uppercase;
  border:1.5px solid var(--bg);
  z-index:2;
  animation:badgeBounce 3s ease-in-out infinite;
}
@keyframes badgeBounce{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.08)}
}

