*{box-sizing:border-box;margin:0;padding:0}
:root{
  --p:#6366f1;--m:#a855f7;--a:#ec4899;--r:#ef4444;
  --bg:#07070a;--tx:#fff;--mut:rgba(255,255,255,.58);
  --g:rgba(255,255,255,.085);--bd:rgba(255,255,255,.12);
  --rad:18px;--dock:92px
}
body{font-family:"DM Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--tx);min-height:100dvh;overflow-x:hidden}
body.light{--bg:#f3f6fb;--tx:#0f172a;--mut:rgba(0,0,0,.55);--g:rgba(255,255,255,.72);--bd:rgba(0,0,0,.12)}

.bg{position:fixed;inset:0;z-index:0}
.bg-img{position:absolute;inset:-20%;background:url("imagen/servi.jpg") center/cover no-repeat;filter:blur(90px) brightness(.35) saturate(1.25);transform:scale(1.06);opacity:.62;transition:opacity .35s,filter .45s,background-image .35s}
body.light .bg-img{filter:blur(90px) brightness(.92) saturate(1.1);opacity:.52}
.bg-vignette{position:absolute;inset:0;background:radial-gradient(80% 50% at 50% 35%, rgba(0,0,0,0) 0%, rgba(0,0,0,.35) 60%, rgba(0,0,0,.70) 100%),linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.20) 45%, rgba(0,0,0,.55));opacity:.98}
body.light .bg-vignette{background:radial-gradient(80% 50% at 50% 35%, rgba(255,255,255,.35) 0%, rgba(255,255,255,.12) 55%, rgba(255,255,255,.35) 100%),linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.22) 45%, rgba(255,255,255,.60));opacity:1}
.bg-grain{position:absolute;inset:-50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");opacity:.12;transform:rotate(8deg);pointer-events:none}

.app{position:relative;z-index:1;max-width:560px;margin:0 auto;min-height:100dvh;padding:calc(env(safe-area-inset-top) + 14px) 16px calc(env(safe-area-inset-bottom) + var(--dock) + 18px)}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.clock{padding:12px 14px;border-radius:var(--rad);background:var(--g);border:1px solid var(--bd);backdrop-filter:blur(16px);display:grid;gap:4px;justify-items:start}
.clock-date{font-size:.72rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--mut);line-height:1.1}
.clock-time{font-family:"DM Mono",ui-monospace,Menlo,monospace;font-size:1.55rem;font-weight:600;line-height:1.1}

.icon{width:44px;height:44px;border-radius:999px;display:grid;place-items:center;background:var(--g);border:1px solid var(--bd);backdrop-filter:blur(16px);cursor:pointer;color:var(--tx);transition:transform .16s,filter .16s}
.icon:hover{transform:scale(1.06);filter:brightness(1.05)}
.icon:active{transform:scale(.96)}
.icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.main{display:grid;place-items:center;gap:14px;padding-top:10px}
.brand{text-align:center;font-family:"Bebas Neue",system-ui,sans-serif;letter-spacing:.06em}
.brand span{display:block}
.brand span:first-child{font-size:2.25rem;opacity:.92}
.brand-grad{font-size:2.65rem;background:linear-gradient(135deg,var(--p),var(--a));-webkit-background-clip:text;background-clip:text;color:transparent}

.hero{width:100%;display:grid;place-items:center;gap:14px}
.cover{width:min(330px,78vw);aspect-ratio:1;position:relative;display:grid;place-items:center}
.aura{position:absolute;inset:-18%;background:radial-gradient(circle at 50% 40%, rgba(168,85,247,.40), transparent 55%),radial-gradient(circle at 45% 70%, rgba(99,102,241,.30), transparent 60%),radial-gradient(circle at 65% 75%, rgba(236,72,153,.22), transparent 62%);filter:blur(18px);opacity:.9;transform:translateZ(0)}
.ring{position:absolute;inset:-10%;border-radius:50%;border:1px solid rgba(255,255,255,.13);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);opacity:.65}
.card{width:100%;height:100%;padding:14px;border-radius:34px;background:var(--g);border:1px solid var(--bd);backdrop-filter:blur(18px);box-shadow:0 24px 90px rgba(0,0,0,.55);animation:floaty 2.9s ease-in-out infinite}
.card img{width:100%;height:100%;object-fit:cover;border-radius:26px;display:block;user-select:none;pointer-events:none}
.live{position:absolute;top:18px;left:18px;display:flex;align-items:center;gap:7px;background:var(--r);color:#fff;padding:6px 12px;border-radius:999px;font-size:.62rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;box-shadow:0 10px 26px rgba(239,68,68,.35)}
.dot{width:7px;height:7px;border-radius:50%;background:#fff}

.meta{width:100%;padding:14px 16px;border-radius:var(--rad);background:var(--g);border:1px solid var(--bd);backdrop-filter:blur(16px);display:grid;gap:6px}
.artist{font-size:.72rem;font-weight:900;letter-spacing:.2em;text-transform:uppercase;color:#c084fc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.title{font-size:1.15rem;font-weight:900;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.social{position:fixed;left:max(12px, env(safe-area-inset-left));top:50%;transform:translateY(-50%);z-index:6;display:flex;flex-direction:column;gap:10px;padding:10px;border-radius:18px;background:rgba(0,0,0,.12);border:1px solid rgba(255,255,255,.10);backdrop-filter:blur(14px)}
body.light .social{background:rgba(255,255,255,.28);border-color:rgba(0,0,0,.10)}
.sbtn{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:var(--mut);cursor:pointer;transition:transform .16s,color .16s,filter .16s}
body.light .sbtn{border-color:rgba(0,0,0,.10);background:rgba(255,255,255,.6)}
.sbtn:hover{transform:scale(1.08);color:var(--tx);filter:brightness(1.06)}
.sbtn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.chat{position:fixed;right:max(14px, env(safe-area-inset-right));bottom:calc(env(safe-area-inset-bottom) + var(--dock) + 12px);z-index:7;display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:18px;border:none;background:linear-gradient(135deg,var(--p),var(--m));color:#fff;font-weight:900;box-shadow:0 16px 40px rgba(99,102,241,.42);cursor:pointer;transition:transform .16s,filter .16s}
.chat:hover{transform:scale(1.05);filter:brightness(1.06)}
.chat:active{transform:scale(.96)}
.chat svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.dock{position:fixed;left:0;right:0;bottom:0;z-index:10;padding:12px 14px calc(env(safe-area-inset-bottom) + 12px);background:rgba(5,5,8,.78);border-top:1px solid var(--bd);backdrop-filter:blur(20px);max-width:560px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
body.light .dock{background:rgba(255,255,255,.78)}
.mini{display:flex;align-items:center;gap:10px;min-width:0}
.mini img{width:46px;height:46px;border-radius:12px;object-fit:cover;flex:0 0 auto}
.mini-text{min-width:0}
.mini-title{font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-live{display:flex;align-items:center;gap:6px;color:var(--mut);font-weight:900;font-size:.62rem;letter-spacing:.12em}
.mini-dot{width:7px;height:7px;border-radius:50%;background:var(--r)}
.play{width:62px;height:62px;border-radius:999px;border:none;cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--p),var(--m));display:grid;place-items:center;box-shadow:0 16px 40px rgba(99,102,241,.46);transition:transform .16s,filter .16s}
.play:hover{transform:scale(1.06);filter:brightness(1.06)}
.play:active{transform:scale(.96)}
.play svg{width:26px;height:26px;stroke:currentColor;fill:currentColor}
.right{display:flex;align-items:center;justify-content:flex-end;gap:10px}
.right input[type="range"]{-webkit-appearance:none;appearance:none;width:92px;height:6px;border-radius:999px;background:rgba(255,255,255,.18);outline:none;cursor:pointer}
body.light .right input[type="range"]{background:rgba(0,0,0,.14)}
.right input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--p);box-shadow:0 0 12px rgba(99,102,241,.55)}
.pct{font-family:"DM Mono",ui-monospace,Menlo,monospace;font-size:.72rem;color:var(--mut);min-width:40px;text-align:right}
.heart svg{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.waves{position:fixed;left:0;right:0;bottom:0;height:190px;z-index:4;pointer-events:none;opacity:.38}

.modal{position:fixed;inset:0;z-index:30;opacity:0;pointer-events:none;transition:opacity .18s ease}
.modal.open{opacity:1;pointer-events:auto}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.modal-card{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-48%) scale(.98);
  width:min(520px,calc(100vw - 28px));
  background:rgba(12,12,16,.92);
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  backdrop-filter:blur(22px);
  overflow:hidden;
  transition:transform .20s cubic-bezier(.2,.9,.2,1)
}
body.light .modal-card{background:rgba(255,255,255,.92);border-color:rgba(0,0,0,.10)}
.modal.open .modal-card{transform:translate(-50%,-50%) scale(1)}
.modal-top{display:flex;align-items:center;justify-content:space-between;padding:14px;border-bottom:1px solid rgba(255,255,255,.10)}
body.light .modal-top{border-bottom-color:rgba(0,0,0,.10)}
.modal-title{font-weight:900}
.modal-body{height:min(52dvh,430px);overflow:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.bubble{max-width:85%;padding:10px 12px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);line-height:1.25}
body.light .bubble{border-color:rgba(0,0,0,.10);background:rgba(0,0,0,.04)}
.bubble.me{margin-left:auto;background:rgba(99,102,241,.16);border-color:rgba(99,102,241,.28)}
.bubble.bot{margin-right:auto}
.modal-input{display:flex;gap:10px;align-items:center;padding:12px 14px 14px;border-top:1px solid rgba(255,255,255,.10)}
body.light .modal-input{border-top-color:rgba(0,0,0,.10)}
.modal-input input{flex:1;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);padding:0 12px;color:var(--tx);outline:none}
body.light .modal-input input{border-color:rgba(0,0,0,.10);background:rgba(0,0,0,.04)}
.send{height:44px;padding:0 14px;border-radius:14px;border:none;background:linear-gradient(135deg,var(--p),var(--m));color:#fff;font-weight:900;cursor:pointer}

@keyframes floaty{0%,100%{transform:translate3d(0,-2px,0)}50%{transform:translate3d(0,6px,0)}}

@media (max-width:410px){
  .pct{display:none}
  .right input[type="range"]{width:74px}
  .mini img{display:none}
  .brand span:first-child{font-size:2.05rem}
  .brand-grad{font-size:2.35rem}
}

@media (prefers-reduced-motion:reduce){
  .card{animation:none}
  .icon,.play,.sbtn,.chat,.modal,.modal-card{transition:none}
}
