/* HERE APP — Design System
   Original Apple-inspired Light/Dark
   Christian Vigliotta */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

:root {
  --bg:#ffffff; --bg2:#f5f5f7; --bg3:#e8e8ed;
  --border:rgba(0,0,0,0.08); --text:#1d1d1f; --text2:#6e6e73; --text3:#aeaeb2;
  --accent:#1d1d1f; --accent-inv:#ffffff; --accent-soft:rgba(29,29,31,0.07);
  --green:#30d158; --blue:#0071e3; --blue-soft:rgba(0,113,227,0.10);
  --red:#ff3b30; --gold:#c9a84c;
  --r:22px; --r-sm:14px; --r-xs:10px;
  --nav-h:82px;
  --shadow:0 2px 20px rgba(0,0,0,0.07);
  --shadow-lg:0 8px 40px rgba(0,0,0,0.12);
}

@media(prefers-color-scheme:dark){:root{
  --bg:#000000; --bg2:#1c1c1e; --bg3:#2c2c2e;
  --border:rgba(255,255,255,0.10); --text:#f5f5f7; --text2:#aeaeb2; --text3:#636366;
  --accent:#f5f5f7; --accent-inv:#000000; --accent-soft:rgba(255,255,255,0.09);
  --blue:#0a84ff; --blue-soft:rgba(10,132,255,0.15); --red:#ff453a;
  --shadow:0 2px 20px rgba(0,0,0,0.40); --shadow-lg:0 8px 40px rgba(0,0,0,0.60);
}}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'DM Sans',-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:inherit;font-weight:600;transition:transform .15s,opacity .15s;text-decoration:none;width:100%;border-radius:50px}
.btn:active{transform:scale(.97);opacity:.85}
.btn-primary{background:var(--accent);color:var(--accent-inv);padding:16px 32px;font-size:17px}
.btn-secondary{background:var(--bg2);color:var(--text);padding:14px 28px;font-size:16px}
.btn-ghost{background:transparent;color:var(--text3);padding:12px;font-size:14px;font-weight:500}
.btn-google{background:#fff;color:#1d1d1f;padding:14px 28px;font-size:15px;border:1.5px solid var(--border);box-shadow:var(--shadow)}

/* ── INPUTS ── */
.inp-wrap{display:flex;flex-direction:column;gap:7px}
.inp-lbl{font-size:13px;font-weight:600;color:var(--text2)}
.inp{background:var(--bg2);border:1.5px solid transparent;border-radius:var(--r-sm);padding:14px 18px;font-size:16px;color:var(--text);outline:none;width:100%;font-family:inherit;transition:border-color .2s}
.inp:focus{border-color:var(--blue)}
.inp::placeholder{color:var(--text3)}

/* ── STEPS BAR ── */
.steps-bar{display:flex;gap:6px}
.steps-bar span{flex:1;height:3px;border-radius:2px;background:var(--bg3);transition:background .3s}
.steps-bar span.done{background:var(--blue)}

/* ── TAGS ── */
.tag{display:inline-flex;align-items:center;padding:7px 14px;border-radius:50px;font-size:13px;font-weight:500;border:1.5px solid var(--border);background:var(--bg2);color:var(--text2);cursor:pointer;transition:all .2s;font-family:inherit;user-select:none}
.tag.sel{background:var(--accent);color:var(--accent-inv);border-color:var(--accent)}
.tags-row{display:flex;flex-wrap:wrap;gap:7px}

/* ── EMOJI GRID ── */
.emoji-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.eo{height:52px;border-radius:14px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;border:2px solid transparent;transition:all .2s;user-select:none}
.eo:active{transform:scale(.93)}
.eo.picked{border-color:var(--blue);background:var(--blue-soft)}

/* ── MOOD ── */
.mood-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.mood-btn{background:var(--bg2);border:1.5px solid transparent;border-radius:var(--r-sm);padding:13px 6px;text-align:center;cursor:pointer;font-family:inherit;color:var(--text2);transition:all .2s}
.mood-btn .me{font-size:22px;display:block;margin-bottom:4px}
.mood-btn .ml{font-size:11px;font-weight:600}
.mood-btn.sel{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}

/* ── BOTTOM NAV ── */
.bnav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;background:var(--bg);border-top:1px solid var(--border);display:flex;padding:8px 0 max(20px,env(safe-area-inset-bottom));z-index:200;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.ni{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:4px 0;text-decoration:none}
.ni-ico{font-size:22px;line-height:1}
.ni-lbl{font-size:10px;font-weight:600;color:var(--text3)}
.ni.active .ni-lbl{color:var(--blue)}

/* ── LIVE DOT ── */
.ldot{width:8px;height:8px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}

/* ── WAVE ── */
.wave{display:flex;align-items:center;gap:2px}
.wave span{width:3px;background:var(--green);border-radius:2px;animation:wv 1.2s ease-in-out infinite}
.wave span:nth-child(2){animation-delay:.15s}
.wave span:nth-child(3){animation-delay:.30s}
.wave span:nth-child(4){animation-delay:.45s}
@keyframes wv{0%,100%{height:4px}50%{height:16px}}
.mw{display:flex;gap:1.5px;align-items:center;flex-shrink:0}
.mw span{width:2px;height:8px;background:var(--green);border-radius:2px;animation:wv .9s ease-in-out infinite}
.mw span:nth-child(2){animation-delay:.12s;height:12px}
.mw span:nth-child(3){animation-delay:.24s}

/* ── TOAST ── */
#toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--text);color:var(--bg);padding:12px 20px;border-radius:50px;font-size:14px;font-weight:600;opacity:0;transition:all .3s;z-index:999;white-space:nowrap;pointer-events:none}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── MODAL ── */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(10px);z-index:500;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-ov.open{opacity:1;pointer-events:all}
.modal-sh{background:var(--bg2);border-radius:var(--r) var(--r) 0 0;padding:20px 24px max(36px,env(safe-area-inset-bottom));width:100%;max-width:430px;transform:translateY(100%);transition:transform .35s cubic-bezier(.25,.46,.45,.94);border-top:1px solid var(--border)}
.modal-ov.open .modal-sh{transform:translateY(0)}
.mhandle{width:36px;height:4px;background:var(--bg3);border-radius:2px;margin:0 auto 20px}

/* ── SKELETON ── */
.skel{background:linear-gradient(90deg,var(--bg2) 25%,var(--bg3) 50%,var(--bg2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-sm)}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ── PERSON CARD ── */
.pcard{background:var(--bg2);border-radius:var(--r-sm);padding:13px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;border:1px solid var(--border);transition:transform .2s}
.pcard:active{transform:scale(.98)}
.pav{width:48px;height:48px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;position:relative}
.ponline{position:absolute;bottom:1px;right:1px;width:11px;height:11px;background:var(--green);border-radius:50%;border:2px solid var(--bg2)}
.pinf{flex:1;min-width:0}
.pname{font-size:14px;font-weight:700;margin-bottom:2px}
.ptrack{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ptags{display:flex;gap:5px;margin-top:5px;flex-wrap:wrap}
.ptag{font-size:10px;padding:2px 8px;border-radius:50px;background:var(--accent-soft);color:var(--text2);font-weight:500}
.wavebtn{width:36px;height:36px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;font-size:16px;border:none;cursor:pointer;flex-shrink:0;transition:transform .2s}
.wavebtn:active{transform:scale(.9)}

/* ── CHAT ── */
.chat-box{background:var(--bg2);border-radius:var(--r);overflow:hidden;border:1px solid var(--border)}
.ch-head{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.ch-title{font-size:15px;font-weight:600}
.ch-live{font-size:12px;color:var(--green);font-weight:600}
.ch-msgs{padding:12px;display:flex;flex-direction:column;gap:9px;max-height:220px;overflow-y:auto}
.msg{display:flex;gap:7px;align-items:flex-end}
.msg.mine{flex-direction:row-reverse}
.msg-av{width:26px;height:26px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.bubble{max-width:75%;padding:9px 13px;border-radius:16px;font-size:13px;line-height:1.45}
.msg:not(.mine) .bubble{background:var(--bg3);color:var(--text);border-bottom-left-radius:5px}
.msg.mine .bubble{background:var(--blue);color:#fff;border-bottom-right-radius:5px}
.ch-inp-row{padding:9px 10px;display:flex;gap:7px;align-items:center;border-top:1px solid var(--border)}
.ch-field{flex:1;background:var(--bg3);border:none;border-radius:50px;padding:9px 14px;font-size:14px;color:var(--text);outline:none;font-family:inherit}
.ch-field::placeholder{color:var(--text3)}
.ch-send{width:34px;height:34px;background:var(--blue);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .15s}
.ch-send:active{transform:scale(.9)}

/* ── MUSIC SEARCH ── */
.music-search-wrap{position:relative}
.music-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);max-height:240px;overflow-y:auto;z-index:300;box-shadow:var(--shadow-lg);display:none}
.music-results.open{display:block}
.mri{padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}
.mri:last-child{border-bottom:none}
.mri:active{background:var(--bg3)}
.mri-title{font-size:14px;font-weight:600}
.mri-artist{font-size:12px;color:var(--text2);margin-top:1px}
.mri-searching{padding:14px 16px;font-size:13px;color:var(--text3);text-align:center}

/* ── MUSIC RECOGNIZE BTN ── */
.recognize-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--bg2);border:1.5px solid var(--border);border-radius:50px;padding:13px 20px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;color:var(--text);width:100%;transition:all .2s}
.recognize-btn.recording{background:var(--red);color:#fff;border-color:var(--red);animation:recPulse 1s ease-in-out infinite}
@keyframes recPulse{0%,100%{opacity:1}50%{opacity:.7}}

/* ── PLUS BANNER ── */
.plus-banner{background:linear-gradient(135deg,rgba(201,168,76,.1),rgba(232,204,122,.05));border:1px solid rgba(201,168,76,.25);border-radius:var(--r);padding:16px;display:flex;align-items:center;gap:14px;cursor:pointer}

/* ── PREF ROWS ── */
.pref-list{background:var(--bg2);border-radius:var(--r-sm);border:1px solid var(--border);overflow:hidden}
.prow{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer}
.prow:last-child{border-bottom:none}
.prow-l{display:flex;align-items:center;gap:12px}
.prow-ico{font-size:20px;width:28px;text-align:center}
.prow-name{font-size:15px;font-weight:500}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes pop{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
.au1{animation:fadeUp .5s .05s both}
.au2{animation:fadeUp .5s .12s both}
.au3{animation:fadeUp .5s .19s both}
.au4{animation:fadeUp .5s .26s both}
.au5{animation:fadeUp .5s .33s both}

/* ── MISC ── */
.page{max-width:430px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;padding-bottom:var(--nav-h)}
.sec-row{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 10px}
.sec-t{font-size:20px;font-weight:600;letter-spacing:-.4px}
.sec-c{font-size:13px;color:var(--text3);font-weight:500}
.or-div{display:flex;align-items:center;gap:12px;color:var(--text3);font-size:13px}
.or-div::before,.or-div::after{content:'';flex:1;height:1px;background:var(--border)}
