/* ===== Entre — Landing page ===== */
:root{
  /* neutros cálidos (claro) */
  --bg:#FBF6F3; --bg2:#F5ECE8; --surface:#FFFFFF; --ink:#2A1E25; --muted:#857580;
  --border:#EEE0DC; --hair:#F2E8E5;
  /* acento rubor */
  --primary:#E8536B; --primary-press:#D33E58; --secondary:#7A4D9C; --gold:#E0913B;
  --primary-soft:#FCE9EC; --gold-soft:#FBEFDD;
  /* oscuro (para secciones de contraste / mockups) */
  --d-bg:#1C141B; --d-surface:#271B26; --d-surface2:#32232F; --d-ink:#F6ECF0;
  --d-muted:#A892A0; --d-border:#3A2A37; --d-primary:#FF6B81; --d-secondary:#B79CFF; --d-gold:#F0B65E;
  /* type */
  --display:"Bricolage Grotesque", system-ui, sans-serif;
  --ui:"Hanken Grotesk", system-ui, sans-serif;
  --shadow:0 20px 50px rgba(42,30,37,.14);
  --shadow-sm:0 6px 20px rgba(42,30,37,.10);
  --maxw:1180px;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{ background:var(--bg); color:var(--ink); font-family:var(--ui); line-height:1.6;
  font-size:17px; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:700; letter-spacing:-.025em; line-height:1.04; }
a{ color:inherit; text-decoration:none; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.eyebrow{ font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--primary); font-weight:700; }

/* ===== Nav ===== */
nav.top{ position:sticky; top:0; z-index:50; backdrop-filter:saturate(1.4) blur(14px);
  background:color-mix(in srgb, var(--bg) 82%, transparent); border-bottom:1px solid transparent; transition:.3s;}
nav.top.scrolled{ border-color:var(--hair); background:color-mix(in srgb, var(--bg) 92%, transparent);}
nav.top .row{ display:flex; align-items:center; justify-content:space-between; height:72px;}
nav.top .brand{ display:flex; align-items:center; gap:11px; }
nav.top .brand .nm{ font-family:var(--display); font-weight:700; font-size:25px; letter-spacing:-.03em; }
nav.top .links{ display:flex; align-items:center; gap:34px; }
nav.top .links a{ font-size:15.5px; font-weight:500; color:var(--muted); transition:.2s;}
nav.top .links a:hover{ color:var(--ink); }
nav.top .links a.btn-primary{ color:#fff; }
nav.top .links a.btn-primary:hover{ color:#fff; }
.btn{ font-family:var(--ui); font-weight:600; font-size:15.5px; border:none; cursor:pointer; border-radius:14px;
  padding:12px 22px; display:inline-flex; align-items:center; gap:9px; transition:transform .14s, box-shadow .2s, background .2s; white-space:nowrap;}
.btn:active{ transform:scale(.97); }
.btn-primary{ background:var(--primary); color:#fff; box-shadow:0 10px 24px color-mix(in srgb,var(--primary) 38%, transparent);}
.btn-primary:hover{ background:var(--primary-press); }
.btn-ghost{ background:var(--surface); color:var(--ink); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ background:#fff; }
@media(max-width:760px){ nav.top .links a:not(.nav-cta){ display:none; } }

/* ===== Hero ===== */
.hero{ position:relative; padding:72px 0 90px; overflow:hidden; }
.hero::before{ content:""; position:absolute; top:-220px; right:-160px; width:620px; height:620px; border-radius:50%;
  background:radial-gradient(circle, color-mix(in srgb,var(--primary) 22%, transparent), transparent 65%); z-index:0;}
.hero::after{ content:""; position:absolute; bottom:-180px; left:-140px; width:480px; height:480px; border-radius:50%;
  background:radial-gradient(circle, color-mix(in srgb,var(--secondary) 16%, transparent), transparent 65%); z-index:0;}
.hero .wrap{ position:relative; z-index:1; display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;}
.hero .badge-line{ display:inline-flex; align-items:center; gap:9px; background:var(--surface); border:1px solid var(--border);
  border-radius:99px; padding:7px 15px 7px 9px; font-size:13.5px; font-weight:600; color:var(--muted); box-shadow:var(--shadow-sm); margin-bottom:24px;}
.hero .badge-line .dot{ width:8px;height:8px;border-radius:50%;background:#3ECF8E;}
.hero h1{ font-size:68px; line-height:.98; margin-bottom:22px; }
.hero h1 .grad{ background:linear-gradient(115deg,var(--primary),var(--secondary)); -webkit-background-clip:text; background-clip:text; color:transparent;}
.hero .tag{ font-size:20px; color:var(--muted); max-width:480px; margin-bottom:18px; }
.hero .tag b{ color:var(--ink); font-weight:600; }
.hero .ctas{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
.hero-cta{ font-size:17px; padding:15px 30px; border-radius:16px; box-shadow:0 14px 30px color-mix(in srgb,var(--primary) 40%, transparent); }
.stores-coming{ margin-top:14px; font-size:13px; color:var(--muted); display:flex; align-items:center; gap:7px; }
.hero .fineprint{ margin-top:14px; font-size:13.5px; color:var(--muted); display:flex; align-items:center; gap:8px;}
.hero .fineprint svg{ flex:0 0 auto; }

/* store buttons */
.store-btn{ display:inline-flex; align-items:center; gap:11px; padding:11px 20px; border-radius:15px; cursor:pointer;
  background:var(--ink); color:#fff; transition:transform .14s, opacity .2s; border:none; font-family:var(--ui);}
.store-btn:active{ transform:scale(.97); }
.store-btn.soon{ background:var(--surface); color:var(--ink); border:1px solid var(--border); box-shadow:var(--shadow-sm);}
.store-btn .st-ic{ flex:0 0 auto; }
.store-btn .st-tx{ text-align:left; line-height:1.15; }
.store-btn .st-tx .s1{ font-size:11px; opacity:.8; display:block; font-weight:500;}
.store-btn .st-tx .s2{ font-size:16.5px; font-weight:700; font-family:var(--display); letter-spacing:-.01em;}
.store-btn.soon .st-tx .s1{ color:var(--primary); opacity:1; font-weight:700;}

/* ===== Phone frame (mockup) ===== */
.phone-hero{ display:flex; justify-content:center; position:relative; }
.phone{ width:316px; border-radius:46px; padding:11px; flex:0 0 auto;
  background:linear-gradient(160deg,#3a3a44,#17171c); box-shadow:0 50px 90px rgba(42,20,30,.4), inset 0 0 0 1.4px rgba(255,255,255,.06);}
.phone.tilt{ transform:rotate(3deg); }
.phone-screen{ border-radius:36px; overflow:hidden; background:var(--d-bg); color:var(--d-ink); position:relative;
  display:flex; flex-direction:column; min-height:650px; }
.ps-status{ display:flex; justify-content:space-between; align-items:center; padding:16px 22px 6px; font-size:13px; font-weight:600;}
.ps-status .sig{ display:flex; gap:4px; align-items:center;}
.ps-appbar{ display:flex; align-items:center; justify-content:space-between; padding:6px 18px 12px;}
.ps-appbar .t{ font-family:var(--display); font-weight:700; font-size:23px; display:flex; align-items:center; gap:8px; letter-spacing:-.02em;}
.ps-icbtn{ width:38px;height:38px;border-radius:12px;background:var(--d-surface); display:flex; align-items:center; justify-content:center; color:var(--d-muted);}

/* discover card in mockup */
.ps-deck{ flex:1; position:relative; padding:2px 16px 0; }
.ps-card{ position:absolute; inset:2px 16px 0; border-radius:26px; overflow:hidden; }
.ps-photo{ position:absolute; inset:0;
  background:linear-gradient(160deg,#F4A6B0 0%,#B86A9E 45%,#523A77 100%);}
.ps-photo::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(20,10,16,.9) 0%, rgba(20,10,16,.32) 36%, transparent 56%);}
.ps-photo .face{ position:absolute; inset:0; opacity:.5;
  background:radial-gradient(60% 45% at 50% 32%, rgba(255,255,255,.5), transparent 70%);}
.ps-dots{ position:absolute; top:14px; left:50%; transform:translateX(-50%); display:flex; gap:5px; z-index:3;}
.ps-dots span{ width:30px;height:3.5px;border-radius:99px;background:rgba(255,255,255,.4);}
.ps-dots span.on{ background:#fff;}
.ps-verified{ position:absolute; top:12px; right:14px; z-index:3; display:flex; align-items:center; gap:6px; font-size:11px; font-weight:600;
  background:rgba(0,0,0,.3); backdrop-filter:blur(5px); color:#fff; padding:5px 10px 5px 7px; border-radius:99px;}
.ps-cardinfo{ position:absolute; left:0; right:0; bottom:0; padding:18px 18px 16px; z-index:3; color:#fff;}
.ps-cardinfo .nm{ font-family:var(--display); font-weight:700; font-size:27px; letter-spacing:-.02em; display:flex; align-items:center; gap:8px;}
.ps-cardinfo .meta{ font-size:13.5px; opacity:.9; margin-top:3px; }
.ps-chips{ display:flex; gap:6px; margin-top:11px; flex-wrap:wrap;}
.ps-chip{ font-size:11.5px; font-weight:600; padding:5px 11px; border-radius:99px; background:rgba(255,255,255,.16);
  color:#fff; backdrop-filter:blur(5px); border:1px solid rgba(255,255,255,.18);}
.ps-chip.accent{ background:var(--d-primary); color:#2a1018; border-color:transparent;}
/* actions */
.ps-actions{ flex:0 0 auto; display:flex; align-items:center; justify-content:center; gap:13px; padding:16px 0 8px;}
.ps-fab{ border:none; border-radius:50%; display:flex; align-items:center; justify-content:center; flex:0 0 auto;}
.ps-fab.sm{ width:42px;height:42px;background:transparent;color:var(--d-muted);}
.ps-fab.md{ width:54px;height:54px;background:var(--d-surface);color:var(--d-ink);box-shadow:0 4px 14px rgba(0,0,0,.4);}
.ps-fab.super{ width:54px;height:54px;background:var(--d-gold);color:#fff;box-shadow:0 8px 18px rgba(240,182,94,.42);}
.ps-fab.like{ width:66px;height:66px;background:var(--d-primary);color:#2a1018;box-shadow:0 12px 26px rgba(255,107,129,.5);}
.ps-fab.boost{ width:42px;height:42px;background:transparent;color:var(--d-secondary);}
/* bottom nav */
.ps-nav{ flex:0 0 auto; display:flex; padding:9px 12px 20px; background:var(--d-surface); border-top:1px solid var(--d-border);}
.ps-nav button{ flex:1; border:none; background:transparent; display:flex; flex-direction:column; align-items:center; gap:4px;
  color:var(--d-muted); font-family:var(--ui); font-size:10px; font-weight:600;}
.ps-nav button.on{ color:var(--d-primary); }

/* ===== generic section ===== */
section.block{ padding:96px 0; position:relative; }
.sec-head{ max-width:680px; margin:0 auto 56px; text-align:center; }
.sec-head h2{ font-size:46px; margin:16px 0 16px; }
.sec-head p{ font-size:19px; color:var(--muted); }

/* ===== Qué es ===== */
.what{ background:var(--bg2); }
.what .lead{ max-width:840px; margin:0 auto; text-align:center;}
.what .lead h2{ font-size:40px; line-height:1.1; }
.what .lead h2 em{ font-style:normal; color:var(--primary); }
.pillars{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:56px; }
.pillar{ background:var(--surface); border:1px solid var(--border); border-radius:24px; padding:34px; box-shadow:var(--shadow-sm);}
.pillar .pic{ width:52px;height:52px;border-radius:15px;background:var(--primary-soft);color:var(--primary);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.pillar h3{ font-size:23px; margin-bottom:9px; }
.pillar p{ font-size:16px; color:var(--muted); }

/* ===== Features ===== */
.feat-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:20px; }
.feat{ background:var(--surface); border:1px solid var(--border); border-radius:24px; padding:30px; box-shadow:var(--shadow-sm);
  transition:transform .2s, box-shadow .2s; }
.feat:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.feat .fic{ width:50px;height:50px;border-radius:14px; display:flex;align-items:center;justify-content:center; margin-bottom:18px;}
.feat h3{ font-size:21px; margin-bottom:8px; }
.feat p{ font-size:15px; color:var(--muted); }
.feat.big{ grid-column:span 3; }
.feat.reg{ grid-column:span 2; }
.feat.half{ grid-column:span 3; }
/* feature hero (álbum privado) */
.feat.big{ display:grid; grid-template-columns:1fr auto; gap:18px; align-items:center; overflow:hidden;
  background:linear-gradient(135deg, var(--ink), #3a2233); color:#fff; border-color:transparent;}
.feat.big h3{ color:#fff; font-size:26px; }
.feat.big p{ color:rgba(255,255,255,.78); font-size:15.5px; }
.feat.big .fic{ background:rgba(255,255,255,.14); color:#fff; }
.lock-visual{ width:120px; height:120px; border-radius:24px; flex:0 0 auto; position:relative;
  background:linear-gradient(135deg,#5a2030,#3d1a2c); display:flex; align-items:center; justify-content:center;}
.lock-visual .blurph{ position:absolute; inset:0; border-radius:24px; filter:blur(12px);
  background:linear-gradient(135deg,#F4A6B0,#B86A9E);} 
.lock-visual .lk{ position:relative; z-index:2; width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.18); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.3);
  display:flex; align-items:center; justify-content:center; color:#fff;}

/* ===== Premium ===== */
.premium{ background:var(--d-bg); color:var(--d-ink); }
.premium .sec-head h2{ color:var(--d-ink); }
.premium .sec-head p{ color:var(--d-muted); }
.plans{ display:grid; grid-template-columns:1fr 1.15fr; gap:22px; max-width:920px; margin:0 auto; align-items:stretch;}
.plan{ border-radius:26px; padding:36px; }
.plan.free{ background:var(--d-surface); border:1px solid var(--d-border); }
.plan.pro{ position:relative; background:linear-gradient(150deg,#2e1c2a,#3a2233); border:1px solid color-mix(in srgb,var(--d-primary) 40%, transparent);
  box-shadow:0 30px 70px rgba(255,107,129,.16);}
.plan .pname{ font-family:var(--display); font-weight:700; font-size:15px; letter-spacing:.05em; text-transform:uppercase; color:var(--d-muted);}
.plan.pro .pname{ color:var(--d-primary); }
.plan .price{ font-family:var(--display); font-weight:800; font-size:40px; margin:12px 0 4px; letter-spacing:-.02em; }
.plan .price small{ font-size:16px; font-weight:500; color:var(--d-muted); font-family:var(--ui);}
.plan .psub{ font-size:14px; color:var(--d-muted); margin-bottom:24px; }
.plan ul{ list-style:none; display:flex; flex-direction:column; gap:13px; }
.plan li{ display:flex; gap:11px; align-items:flex-start; font-size:15.5px; color:var(--d-ink);}
.plan li svg{ flex:0 0 auto; margin-top:3px; }
.plan li.off{ color:var(--d-muted); }
.plan .badge-pop{ position:absolute; top:22px; right:22px; background:var(--d-primary); color:#2a1018;
  font-size:12px; font-weight:700; padding:5px 12px; border-radius:99px;}
.plan .plan-cta{ margin-top:28px; }
.plan-trial{ margin-top:12px; font-size:12.5px; color:var(--d-muted); text-align:center; }
.plan.pro .btn-primary{ background:var(--d-primary); color:#2a1018; width:100%; justify-content:center;
  box-shadow:0 10px 26px rgba(255,107,129,.4);}
.plan.free .plan-cta .btn{ width:100%; justify-content:center; background:transparent; border:1px solid var(--d-border); color:var(--d-ink);}

/* ===== Descarga ===== */
.download{ background:var(--bg2); }
.dl-card{ background:linear-gradient(135deg,var(--primary),var(--secondary)); border-radius:34px; padding:60px 56px;
  display:grid; grid-template-columns:1fr auto; gap:40px; align-items:center; color:#fff; box-shadow:var(--shadow); overflow:hidden; position:relative;}
.dl-card::before{ content:""; position:absolute; top:-120px; right:30%; width:340px; height:340px; border-radius:50%;
  background:rgba(255,255,255,.12);}
.dl-card .dl-tx{ position:relative; z-index:2; }
.dl-card h2{ font-size:44px; color:#fff; margin-bottom:14px; }
.dl-card p{ font-size:18px; color:rgba(255,255,255,.9); max-width:420px; margin-bottom:28px;}
.dl-card .ctas{ display:flex; gap:14px; flex-wrap:wrap; }
.dl-card .store-btn{ background:#fff; color:var(--ink); box-shadow:0 10px 30px rgba(0,0,0,.18);}
.dl-card .store-btn.soon{ background:rgba(255,255,255,.16); color:#fff; border:1px solid rgba(255,255,255,.3);}
.dl-card .store-btn.soon .st-tx .s1{ color:#fff; }
.dl-web-btn{ background:#fff; color:var(--ink); box-shadow:0 10px 30px rgba(0,0,0,.18); }
.stores-pills{ display:flex; flex-wrap:wrap; gap:9px; margin-top:16px; }
.store-pill{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); border-radius:99px; padding:5px 13px; }
.dl-card .age{ margin-top:20px; font-size:13.5px; color:rgba(255,255,255,.82); display:flex; align-items:center; gap:8px;}
.dl-phones{ position:relative; z-index:2; display:flex; }
.dl-phones .mini-phone{ width:150px; border-radius:30px; padding:7px; background:#17171c; box-shadow:0 30px 50px rgba(0,0,0,.3);}
.dl-phones .mini-screen{ border-radius:24px; overflow:hidden; min-height:300px; background:var(--d-bg); }

/* ===== Footer ===== */
footer.site{ background:var(--ink); color:#fff; padding:64px 0 40px; }
footer.site .frow{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.1);}
footer.site .fbrand{ max-width:300px; }
footer.site .fbrand .nm{ font-family:var(--display); font-weight:700; font-size:26px; display:flex; align-items:center; gap:10px; margin-bottom:14px;}
footer.site .fbrand p{ font-size:15px; color:rgba(255,255,255,.6); }
footer.site .fcols{ display:flex; gap:64px; flex-wrap:wrap; }
footer.site .fcol h4{ font-family:var(--ui); font-size:13px; text-transform:uppercase; letter-spacing:.1em; color:rgba(255,255,255,.5); margin-bottom:16px; font-weight:700;}
footer.site .fcol a{ display:block; font-size:15px; color:rgba(255,255,255,.78); margin-bottom:11px; transition:.2s;}
footer.site .fcol a:hover{ color:#fff; }
footer.site .social{ display:flex; gap:12px; }
footer.site .social a{ width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#fff;transition:.2s;}
footer.site .social a:hover{ background:var(--primary); }
footer.site .fbot{ display:flex; justify-content:space-between; align-items:center; padding-top:28px; flex-wrap:wrap; gap:14px;}
footer.site .fbot p{ font-size:13.5px; color:rgba(255,255,255,.5); }
footer.site .fbot .age18{ display:inline-flex; align-items:center; gap:7px; font-size:13px; color:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.18); border-radius:99px; padding:5px 13px;}

/* ===== reveal on scroll ===== */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .55s ease, transform .55s ease; }
.reveal.revealed{ opacity:1; transform:none; }

/* ===== responsive ===== */
@media(max-width:960px){
  .hero .wrap{ grid-template-columns:1fr; text-align:center; }
  .hero .badge-line{ }
  .phone-hero{ margin-top:40px; }
  .feat-grid{ grid-template-columns:repeat(2,1fr); }
  .feat.big,.feat.reg,.feat.half{ grid-column:span 2; }
  .plans{ grid-template-columns:1fr; }
  .dl-card{ grid-template-columns:1fr; text-align:center; }
  .dl-card .ctas{ justify-content:center; }
  .dl-card .age{ justify-content:center; }
  .dl-phones{ justify-content:center; }
  .hero .ctas{ justify-content:center; }
  .hero .fineprint{ justify-content:center; }
}
@media(max-width:680px){
  .hero h1{ font-size:48px; }
  .sec-head h2,.what .lead h2,.dl-card h2{ font-size:34px; }
  .pillars{ grid-template-columns:1fr; }
  .feat-grid{ grid-template-columns:1fr; }
  .feat.big,.feat.reg,.feat.half{ grid-column:span 1; }
  .feat.big{ grid-template-columns:1fr; text-align:left; }
  section.block{ padding:68px 0; }
  .dl-card{ padding:40px 28px; }
  .wrap{ padding:0 20px; }
}

/* ===== Modal Próximamente ===== */
.cs-overlay{
  display:none; position:fixed; inset:0; z-index:1000;
  background:rgba(28,20,27,.72); backdrop-filter:blur(10px);
  align-items:center; justify-content:center; padding:20px;
}
.cs-overlay.open{ display:flex; }
.cs-card{
  background:var(--d-surface); border:1px solid var(--d-border);
  border-radius:1.75rem; padding:48px 40px 40px;
  max-width:420px; width:100%; text-align:center; position:relative;
  box-shadow:0 32px 80px rgba(0,0,0,.5);
  animation:cs-in .28s cubic-bezier(.34,1.5,.64,1) both;
}
@keyframes cs-in{
  from{ opacity:0; transform:scale(.9) translateY(16px); }
  to  { opacity:1; transform:scale(1)  translateY(0); }
}
.cs-x{
  position:absolute; top:14px; right:14px;
  background:var(--d-surface2); border:none; border-radius:50%;
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--d-muted); transition:background .2s,color .2s;
}
.cs-x:hover{ background:var(--d-border); color:var(--d-ink); }
.cs-logo{ margin-bottom:22px; }
.cs-over{
  font-size:11.5px; font-weight:700; letter-spacing:.15em; text-transform:uppercase;
  color:var(--d-primary); margin-bottom:10px;
}
.cs-card h2{
  font-family:var(--display); font-size:2.1rem; line-height:1.05;
  margin-bottom:14px;
  background:linear-gradient(115deg,var(--d-primary),var(--d-secondary));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.cs-body{ font-size:15px; color:var(--d-muted); margin-bottom:28px; line-height:1.65; }
.cs-cta{
  width:100%; justify-content:center; font-size:16px;
  padding:14px 24px; border-radius:14px; cursor:pointer;
}
@media(max-width:480px){
  .cs-card{ padding:40px 22px 32px; }
  .cs-card h2{ font-size:1.75rem; }
}
