/* ═══════════════════════════════════════════════════════════
   BETHER STUDIO · COMPONENTES
   Cada bloque es independiente: Button, Card, PhoneMockup,
   SectionTitle, PortfolioCard, Testimonial, ContactForm,
   FloatingWA, Modal "efecto app".
═══════════════════════════════════════════════════════════ */

/* ══ BUTTON ════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:15px 30px;border-radius:var(--r-btn);
  font-weight:700;font-size:.95rem;letter-spacing:.01em;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s;
  white-space:nowrap;
}
.btn:active{transform:scale(.97)}
.btn svg{flex:none}

.btn--gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-2));
  color:var(--ink);
  box-shadow:0 8px 28px rgba(212,165,116,.25);
}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 14px 38px rgba(212,165,116,.38)}

.btn--wa{
  background:var(--wa);color:#06250f;
  box-shadow:0 8px 28px rgba(37,211,102,.25);
}
.btn--wa:hover{transform:translateY(-2px);box-shadow:0 14px 38px rgba(37,211,102,.4)}

.btn--ghost{
  background:var(--glass-bg);
  border:1px solid var(--line-2);
  color:var(--txt);
  backdrop-filter:blur(8px);
}
.btn--ghost:hover{background:var(--glass-bg-hov);border-color:rgba(212,165,116,.45)}

.btn--sm{padding:10px 20px;font-size:var(--fs-small)}

/* ══ CARD (glassmorphism base) ═════════════════════════════ */
.card{
  background:var(--glass-bg);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  backdrop-filter:blur(var(--glass-blur));
  -webkit-backdrop-filter:blur(var(--glass-blur));
  box-shadow:var(--sh-card);
  padding:30px 26px;
  transition:transform .35s var(--ease), border-color .35s, background .35s, box-shadow .35s;
  position:relative;overflow:hidden;
}
.card:hover{
  transform:translateY(-6px);
  background:var(--glass-bg-hov);
  border-color:rgba(212,165,116,.30);
  box-shadow:var(--sh-card), var(--glow-gold);
}
.card__icon{font-size:1.9rem;margin-bottom:16px}
.card__title{font-size:var(--fs-h3);font-weight:700;margin-bottom:10px;color:var(--txt)}
.card__desc{color:var(--txt-2);font-size:.94rem}
.card__tag{
  position:absolute;top:18px;right:18px;
  font-size:var(--fs-tiny);font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gold-2);
  background:rgba(212,165,116,.12);
  border:1px solid rgba(212,165,116,.3);
  padding:5px 11px;border-radius:99px;
}
.card__cta{
  margin-top:18px;display:inline-flex;align-items:center;gap:7px;
  font-size:var(--fs-small);font-weight:700;color:var(--gold-2);
  transition:gap .25s var(--ease);
}
.card:hover .card__cta{gap:12px}

/* ══ SECTION TITLE ═════════════════════════════════════════ */
.sec-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:var(--fs-tiny);font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold-2);
  border:1px solid rgba(212,165,116,.3);
  background:rgba(212,165,116,.07);
  padding:7px 15px;border-radius:99px;
  margin-bottom:18px;
}
.sec-title{
  font-family:var(--f-display);
  font-size:var(--fs-h2);font-weight:400;line-height:1.05;
  letter-spacing:-.02em;text-wrap:balance;
  margin-bottom:14px;
}
.sec-title em{
  font-style:italic;
  background:linear-gradient(120deg,var(--gold),var(--gold-3));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.sec-sub{color:var(--txt-2);max-width:560px;font-size:1.02rem}
.sec-header{margin-bottom:clamp(38px,5vw,60px)}
.sec-header--center{text-align:center}
.sec-header--center .sec-sub{margin:0 auto}

/* ══ PHONE MOCKUP ══════════════════════════════════════════
   Estructura (la genera PhoneMockup() en app.js):
   .phone > .phone__glow + .phone__frame > notch/screen/home
   La screen lleva una .phone__cover (portada) y opcionalmente
   un iframe que se activa en el modal.                       */
.phone{position:relative;width:clamp(240px,28vw,340px)}
.phone__glow{
  position:absolute;top:52%;left:50%;
  transform:translate(-50%,-50%);
  width:130%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,
    rgba(212,165,116,.20) 0%,
    rgba(255,93,122,.10) 42%,
    transparent 70%);
  filter:blur(38px);
  animation:glowPulse 4.5s ease-in-out infinite;
  pointer-events:none;
}
.phone__frame{
  position:relative;z-index:2;
  background:linear-gradient(160deg,#1e1e24,#13131a);
  border-radius:46px;padding:13px;
  box-shadow:var(--sh-phone);
  animation:floatPhone 6.5s ease-in-out infinite;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  will-change:transform;
}
.phone--tilting .phone__frame{animation:none;transition:transform .15s ease-out}
.phone__notch{
  width:108px;height:25px;margin:0 auto 8px;
  background:#09090b;border-radius:0 0 17px 17px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.phone__cam{width:9px;height:9px;border-radius:50%;background:#1a1a20;border:1.5px solid rgba(255,255,255,.07)}
.phone__spk{width:42px;height:4px;border-radius:99px;background:#1a1a20}
.phone__screen{
  position:relative;overflow:hidden;
  background:#09090b;border-radius:34px;
  aspect-ratio:9/19.5;
  cursor:pointer;
}
.phone__home{width:78px;height:4px;border-radius:99px;background:rgba(255,255,255,.2);margin:10px auto 2px}

/* Reflejo dinámico: lo mueve el JS con --rx/--ry */
.phone__reflect{
  position:absolute;inset:0;z-index:4;border-radius:34px;pointer-events:none;
  background:radial-gradient(220px circle at var(--rx,30%) var(--ry,20%),
    rgba(255,255,255,.10), transparent 60%);
  opacity:0;transition:opacity .3s;
}
.phone:hover .phone__reflect{opacity:1}

/* Portada */
.phone__cover{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:8px;padding:22px;
}
.phone__cover::after{ /* shimmer sweep */
  content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.08) 50%,transparent 60%);
  background-size:200% 100%;
  animation:shimmer 4.5s ease-in-out infinite;
}
.phone__emojis{font-size:2.3rem}
.phone__title{
  font-family:var(--f-display);
  font-size:1.5rem;font-weight:300;color:#fff;line-height:1.1;
}
.phone__title strong{font-weight:600}
.phone__hint{font-size:10px;color:rgba(255,255,255,.6);letter-spacing:.5px}
.phone__play{
  position:relative;width:52px;height:52px;margin-top:6px;
}
.phone__play-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid rgba(212,165,116,.6);
  animation:pulseRing 1.8s ease-out infinite;
}
.phone__play-dot{
  position:absolute;inset:0;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--gold),var(--gold-3));
  color:var(--ink);font-size:15px;font-weight:700;
  box-shadow:0 0 22px rgba(212,165,116,.45);
}

/* Badges flotantes alrededor del phone */
.phone__badge{
  position:absolute;z-index:10;
  display:flex;align-items:center;gap:10px;
  background:rgba(15,15,20,.92);
  border:1px solid rgba(255,255,255,.1);
  backdrop-filter:blur(16px);
  border-radius:14px;padding:10px 14px;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
  animation:badgeFloat 4s ease-in-out infinite;
}
.phone__badge--1{left:clamp(-28px,-4vw,-44px);top:20%;border-color:rgba(74,222,128,.25)}
.phone__badge--2{right:clamp(-28px,-4vw,-48px);bottom:26%;border-color:rgba(212,165,116,.25);animation-delay:-2s}
.phone__badge b{display:block;font-size:11px;color:#fff}
.phone__badge span{font-size:9.5px;color:var(--txt-3);white-space:nowrap}
.phone__badge .ic{font-size:1.15rem}

/* ══ PORTFOLIO CARD ════════════════════════════════════════ */
.pcard{
  position:relative;overflow:hidden;
  border-radius:var(--r-card);
  border:1px solid var(--line);
  background:var(--ink-2);
  cursor:pointer;
  transition:transform .4s var(--ease), border-color .4s, box-shadow .4s;
}
.pcard:hover{
  transform:translateY(-8px) scale(1.015);
  border-color:rgba(212,165,116,.35);
  box-shadow:0 24px 60px rgba(0,0,0,.55), var(--glow-gold);
}
.pcard__cover{
  position:relative;
  aspect-ratio:9/12.5;
  display:flex;align-items:center;justify-content:center;
  font-size:3.4rem;
  overflow:hidden;
}
.pcard__cover::after{ /* viñeta para legibilidad */
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top, rgba(8,8,12,.85) 0%, transparent 45%);
}
.pcard__cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pcard__emoji{position:relative;z-index:1;filter:drop-shadow(0 8px 24px rgba(0,0,0,.5));transition:transform .4s var(--ease)}
.pcard:hover .pcard__emoji{transform:scale(1.18) rotate(-4deg)}
.pcard__body{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:16px 18px;
}
.pcard__cat{
  font-size:var(--fs-tiny);font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold-2);
}
.pcard__title{font-weight:800;font-size:1.02rem;color:#fff;line-height:1.25}
.pcard__tema{font-size:var(--fs-small);color:var(--txt-2)}
.pcard__action{
  margin-top:10px;
  display:inline-flex;align-items:center;gap:7px;
  font-size:var(--fs-tiny);font-weight:800;letter-spacing:.04em;
  color:#fff;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(8px);
  padding:8px 14px;border-radius:99px;
  transition:background .25s,border-color .25s;
}
.pcard:hover .pcard__action{background:rgba(212,165,116,.22);border-color:rgba(212,165,116,.5)}
.pcard__action .play{font-size:.6rem}

/* ══ TESTIMONIAL ═══════════════════════════════════════════ */
.tcard{padding-top:38px}
.tcard__quote{
  position:absolute;top:14px;left:22px;
  font-family:var(--f-display);font-size:3.4rem;line-height:1;
  color:rgba(212,165,116,.4);
}
.tcard__text{color:var(--txt-2);font-size:.97rem;font-style:italic}
.tcard__who{margin-top:16px;font-size:var(--fs-small)}
.tcard__who b{color:var(--gold-2)}
.tcard__who span{color:var(--txt-3)}
.tcard__stars{color:var(--gold);letter-spacing:2px;font-size:.8rem;margin-bottom:8px}

/* ══ CONTACT FORM ══════════════════════════════════════════ */
.form{display:grid;gap:16px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form label{
  display:block;font-size:var(--fs-tiny);font-weight:800;
  letter-spacing:.1em;text-transform:uppercase;color:var(--txt-3);
  margin-bottom:7px;
}
.form input,.form select,.form textarea{
  width:100%;
  background:rgba(255,255,255,.05);
  border:1px solid var(--line-2);
  border-radius:13px;
  color:var(--txt);
  font:inherit;font-size:.95rem;
  padding:13px 15px;
  transition:border-color .25s, background .25s;
}
.form select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--txt-3) 50%),linear-gradient(135deg,var(--txt-3) 50%,transparent 50%);background-position:calc(100% - 20px) 50%,calc(100% - 14px) 50%;background-size:6px 6px;background-repeat:no-repeat}
.form select option{background:var(--ink-2);color:var(--txt)}
.form textarea{min-height:110px;resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;border-color:rgba(212,165,116,.55);
  background:rgba(255,255,255,.07);
}
.form input::placeholder,.form textarea::placeholder{color:var(--txt-3)}
.form__note{font-size:var(--fs-tiny);color:var(--txt-3);text-align:center}

/* ══ FLOATING WHATSAPP ═════════════════════════════════════ */
.fab-wa{
  position:fixed;right:22px;bottom:22px;z-index:9000;
  width:58px;height:58px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--wa);color:#fff;
  box-shadow:0 12px 32px rgba(0,0,0,.45);
  animation:waPulse 2.6s infinite;
  transition:transform .25s var(--ease);
}
.fab-wa:hover{transform:scale(1.1)}
.fab-wa svg{width:30px;height:30px}

/* ══ MODAL "EFECTO APP" ════════════════════════════════════
   El teléfono se expande a primer plano con la demo adentro. */
.appmodal{
  position:fixed;inset:0;z-index:99999;
  display:none;
  align-items:center;justify-content:center;
  background:rgba(5,5,8,.88);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.appmodal.open{display:flex}
.appmodal__phone{
  position:relative;
  background:linear-gradient(160deg,#1e1e24,#13131a);
  padding:12px;
  display:flex;flex-direction:column;
  box-shadow:var(--sh-phone), 0 0 70px rgba(212,165,116,.16);
  transition:transform .55s var(--ease-pop), opacity .4s ease;
  will-change:transform;
}
.appmodal__notch{
  width:108px;height:24px;margin:0 auto 8px;
  background:#09090b;border-radius:0 0 16px 16px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.appmodal__screen{
  position:relative;width:100%;
  aspect-ratio:9/19.5;
  background:#09090b;overflow:hidden;
}
.appmodal__screen iframe{
  position:absolute;inset:0;width:100%;height:100%;border:none;display:block;
}
.appmodal__loader{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:var(--txt-3);
}
.appmodal__loader::after{
  content:"";width:34px;height:34px;border-radius:50%;
  border:2.5px solid rgba(212,165,116,.2);
  border-top-color:var(--gold);
  animation:spinSlow .8s linear infinite;
}
.appmodal__home{width:76px;height:4px;border-radius:99px;background:rgba(255,255,255,.2);margin:9px auto 1px}
.appmodal__close{
  position:fixed;top:20px;right:20px;z-index:2;
  width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);
  border:1px solid var(--line-2);
  backdrop-filter:blur(10px);
  color:#fff;font-size:18px;
  transition:background .25s, transform .25s;
}
.appmodal__close:hover{background:rgba(255,93,122,.25);transform:rotate(90deg)}
.appmodal__label{
  position:fixed;bottom:26px;left:50%;transform:translateX(-50%);
  font-size:var(--fs-small);color:var(--txt-2);
  background:rgba(255,255,255,.06);border:1px solid var(--line);
  padding:9px 18px;border-radius:99px;backdrop-filter:blur(10px);
  white-space:nowrap;
}
