/* ============================================================
   Pink Jobs — Design System v2 "Rosé Clean"
   Marketplace nacional, light, editorial e direto.
   Display: Bricolage Grotesque · Body: Schibsted Grotesk
   Tokens mantêm os nomes herdados (--neon, --bg-3, --line…)
   porque páginas têm estilos inline que os referenciam.
   ============================================================ */

:root{
  --bg:#FFFFFF;
  --bg-2:#FBF4F8;
  --bg-3:#F7EDF3;
  --bg-4:#F0DFE9;
  --neon:#E61E7E;
  --neon-2:#FF7AB8;
  --neon-deep:#B81260;
  --neon-soft:rgba(230,30,126,.08);
  --acid:#B98A4A;
  --text:#241019;
  --text-2:#43293A;
  --text-dim:#8A6B7C;
  --text-dim-2:#C2A7B4;
  --line:#F2DEE9;
  --line-strong:#E5C8D8;
  --line-neon:rgba(230,30,126,.35);
  --glow:0 6px 20px rgba(230,30,126,.22);
  --glow-soft:0 10px 40px rgba(230,30,126,.10);
  --shadow-md:0 2px 6px rgba(74,16,48,.05), 0 12px 32px rgba(74,16,48,.07);
  --shadow-lg:0 4px 10px rgba(74,16,48,.06), 0 24px 60px rgba(74,16,48,.12);
  --radius:14px;
  --radius-lg:22px;
  --max:1280px;
  --t-fast:.16s;
  --t-mid:.3s;
  --t-slow:.55s;
  --font-display:'Bricolage Grotesque','Schibsted Grotesk',system-ui,sans-serif;
  --font-body:'Schibsted Grotesk',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;font-size:16px;
}
img{max-width:100%;display:block}
a{color:var(--neon);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--neon-deep)}
button{font:inherit;cursor:pointer}
::selection{background:var(--neon);color:#fff}
:focus-visible{outline:2px solid var(--neon);outline-offset:2px;border-radius:4px}

body{opacity:0;transition:opacity var(--t-slow) ease}
body.ready{opacity:1}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{transition:none!important;animation:none!important}}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.08;letter-spacing:-.02em;color:var(--text)}
h1{font-weight:800}
.neon{color:var(--neon)}
.outline{color:var(--neon-2)}
.eyebrow{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--neon);font-weight:700}

.container{max-width:var(--max);margin:0 auto;padding:0 1.4rem;position:relative}
section{padding:3.6rem 0}

/* ---------------- HEADER ---------------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{
  max-width:var(--max);margin:0 auto;padding:.85rem 1.4rem;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}
.logo{
  font-family:var(--font-display);font-size:1.5rem;font-weight:800;
  letter-spacing:-.03em;color:var(--text);text-transform:lowercase;
  display:flex;align-items:center;gap:.1em;line-height:1;
}
.logo:hover{color:var(--text)}
.logo .slash{color:var(--neon);font-size:.78em;margin:0 .06em;transform:translateY(-.05em);transition:transform var(--t-fast)}
.logo:hover .slash{transform:translateY(-.05em) scale(1.25)}
.nav-links{display:flex;align-items:center;gap:1.6rem;list-style:none}
.nav-links a{color:var(--text-2);font-size:.92rem;font-weight:600;padding:.3rem 0;position:relative}
.nav-links a:hover{color:var(--neon)}
.nav-links a.btn-cta{
  background:var(--neon);color:#fff;padding:.62rem 1.3rem;border-radius:999px;
  box-shadow:var(--glow);transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
}
.nav-links a.btn-cta:hover{background:var(--neon-deep);transform:translateY(-1px)}
.nav-mobile-cta{display:none}
.mcta-login{font-weight:700;font-size:.9rem}
.mobile-menu{display:none;background:none;border:0;font-size:1.7rem;color:var(--text);line-height:1}

/* ---------------- HERO (home) ---------------- */
.hero{
  position:relative;padding:5rem 0 3.4rem;overflow:hidden;
  background:
    radial-gradient(640px 420px at 88% -10%, rgba(255,122,184,.16), transparent 65%),
    radial-gradient(520px 380px at -6% 30%, rgba(230,30,126,.07), transparent 60%),
    var(--bg-2);
  border-bottom:1px solid var(--line);
}
.hero::after{ /* coração watermark */
  content:"♥";position:absolute;right:-1.5rem;bottom:-7rem;
  font-size:24rem;line-height:1;color:var(--neon);opacity:.05;
  transform:rotate(-12deg);pointer-events:none;font-family:var(--font-display);
}
.hero-inner{max-width:840px;margin:0 auto;padding:0 1.4rem;text-align:center;position:relative;z-index:1}
.hero h1{
  font-size:clamp(2.5rem,6vw,4.2rem);margin:1rem 0 1.1rem;letter-spacing:-.035em;
  animation:rise .7s ease both;
}
.hero h1 em{font-style:normal;color:var(--neon);position:relative;white-space:nowrap}
.hero h1 em::after{
  content:"";position:absolute;left:0;right:0;bottom:.04em;height:.14em;border-radius:99px;
  background:linear-gradient(90deg,var(--neon-2),var(--neon));opacity:.28;
}
.hero-tagline{
  color:var(--text-2);font-size:1.08rem;max-width:600px;margin:0 auto 2.1rem;
  animation:rise .7s .08s ease both;
}
.hero-kicker{
  display:inline-flex;align-items:center;gap:.5rem;
  background:#fff;border:1px solid var(--line-strong);border-radius:999px;
  padding:.4rem 1rem;font-size:.8rem;font-weight:600;color:var(--text-2);
  box-shadow:var(--shadow-md);animation:rise .7s ease both;
}
.hero-kicker .dot{width:8px;height:8px;border-radius:50%;background:#22C55E;display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.45)}50%{box-shadow:0 0 0 6px rgba(34,197,94,0)}}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* Busca integrada ao hero */
.hero-search{
  display:grid;grid-template-columns:1.2fr 1.2fr auto;gap:.55rem;
  background:#fff;border:1px solid var(--line-strong);border-radius:18px;
  padding:.55rem;box-shadow:var(--shadow-lg);max-width:680px;margin:0 auto;
  animation:rise .7s .16s ease both;
}
.hero-search select{
  appearance:none;border:0;background:var(--bg-2);border-radius:12px;
  padding:.95rem 2.3rem .95rem 1.05rem;font:inherit;font-weight:600;color:var(--text);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%23E61E7E' d='M0 0l5 6 5-6z'/></svg>");
  background-repeat:no-repeat;background-position:right .9rem center;cursor:pointer;min-width:0;
}
.hero-search button{
  border:0;background:var(--neon);color:#fff;font-weight:700;border-radius:12px;
  padding:.95rem 1.6rem;box-shadow:var(--glow);white-space:nowrap;
  transition:background var(--t-fast),transform var(--t-fast);
}
.hero-search button:hover{background:var(--neon-deep);transform:translateY(-1px)}
.hero-trust{
  display:flex;justify-content:center;flex-wrap:wrap;gap:1.4rem;margin-top:1.6rem;
  font-size:.84rem;color:var(--text-dim);font-weight:600;
  animation:rise .7s .24s ease both;
}
.hero-trust span{display:inline-flex;align-items:center;gap:.4rem}
.hero-trust b{color:var(--neon)}

/* Hero compacto (páginas internas: planos etc.) */
.hero-grid{max-width:var(--max);margin:0 auto;padding:0 1.4rem;display:grid;grid-template-columns:1.5fr 1fr;gap:3rem;align-items:center}
.hero-grid h1{font-size:clamp(2.2rem,4.6vw,3.4rem);margin:.9rem 0 1rem;letter-spacing:-.03em}
.hero-meta-top{display:flex;align-items:center;gap:.55rem;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--neon)}
.hero-meta-top .dot{width:8px;height:8px;border-radius:50%;background:var(--neon);display:inline-block}
.hero-tagline{color:var(--text-2)}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.6rem}
.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.hero-stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow-md)}
.hero-stat .k{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);display:block;margin-bottom:.3rem;font-weight:700}
.hero-stat .v{font-family:var(--font-display);font-weight:800;font-size:1.9rem;line-height:1;color:var(--text);display:block}
.hero-stat .v.neon{color:var(--neon)}

/* ---------------- BOTÕES ---------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  background:var(--neon);color:#fff;font-weight:700;font-size:.95rem;
  border:0;border-radius:999px;padding:.85rem 1.7rem;box-shadow:var(--glow);
  transition:background var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);
}
.btn:hover{background:var(--neon-deep);color:#fff;transform:translateY(-1px)}
.btn.ghost{background:#fff;color:var(--neon);border:1.5px solid var(--line-neon);box-shadow:none}
.btn.ghost:hover{border-color:var(--neon);background:var(--neon-soft)}
.btn-full{
  display:block;width:100%;background:var(--neon);color:#fff;font-weight:700;
  border:0;border-radius:12px;padding:.95rem;box-shadow:var(--glow);font-size:1rem;
  transition:background var(--t-fast),transform var(--t-fast);
}
.btn-full:hover{background:var(--neon-deep)}
.btn-full:disabled{opacity:.55;cursor:not-allowed;transform:none}
.action-btn{
  background:#fff;border:1px solid var(--line-strong);border-radius:999px;
  padding:.5rem 1rem;font-size:.82rem;font-weight:600;color:var(--text-2);
  transition:border-color var(--t-fast),color var(--t-fast);
}
.action-btn:hover{border-color:var(--neon);color:var(--neon)}
.btn-whatsapp{
  display:flex;align-items:center;justify-content:center;gap:.6rem;
  background:#1EBE5D;color:#fff;font-weight:800;font-size:1.05rem;
  border-radius:14px;padding:1.05rem 1.5rem;margin-top:1.4rem;
  box-shadow:0 8px 24px rgba(30,190,93,.32);
  transition:transform var(--t-fast),box-shadow var(--t-fast);
}
.btn-whatsapp:hover{color:#fff;transform:translateY(-2px);box-shadow:0 12px 30px rgba(30,190,93,.4)}
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:.7rem;width:100%;
  background:#fff;border:1px solid var(--line-strong);border-radius:12px;
  padding:.85rem;font-weight:600;color:var(--text);font-size:.95rem;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.btn-google:hover{border-color:var(--text-dim-2);box-shadow:var(--shadow-md)}
.btn-google svg{width:20px;height:20px}
.btn-switch-cta{width:100%;margin-top:.5rem}

/* ---------------- FORMS ---------------- */
.form-group{margin-bottom:1.05rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.form-group label{
  display:block;font-size:.78rem;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--text-dim);margin-bottom:.4rem;
}
.form-group input,.form-group select,.form-group textarea,
.filter-group select{
  width:100%;background:var(--bg-2);border:1.5px solid var(--line);border-radius:12px;
  padding:.8rem 1rem;font:inherit;color:var(--text);
  transition:border-color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--neon);background:#fff;box-shadow:0 0 0 4px var(--neon-soft);
}
.form-group input.field-error,.form-group select.field-error{border-color:#E5484D;background:#FFF6F6}
.form-help{font-size:.8rem;color:var(--text-dim);margin-top:.35rem}
.checkbox-row{display:flex;align-items:flex-start;gap:.6rem;font-size:.86rem;color:var(--text-2);margin:.9rem 0}
.checkbox-row input{width:18px;height:18px;accent-color:var(--neon);margin-top:.15rem;flex:none}
.password-meter{display:flex;flex-direction:column;gap:.3rem;margin-top:.5rem;font-size:.8rem;color:var(--text-dim)}
.password-meter .ok{color:#16A34A}
.pw-ic{display:inline-block;width:1.2em}
.field-error-msg{color:#E5484D;font-size:.8rem;margin-top:.3rem;font-weight:600}

/* ---------------- ALERTAS / ESTADOS ---------------- */
.alert{border-radius:12px;padding:.95rem 1.15rem;font-size:.92rem;margin-bottom:1.2rem;border:1px solid}
.alert.info{background:var(--neon-soft);border-color:var(--line-neon);color:var(--text-2)}
.alert.error{background:#FFF1F1;border-color:#F5C2C7;color:#9F1239}
.alert.success{background:#EFFBF3;border-color:#BBE7C9;color:#14532D}
.empty{color:var(--text-dim);text-align:center;padding:3rem 1rem;font-size:.95rem}
.loading{display:flex;align-items:center;justify-content:center;gap:.8rem;padding:4rem;color:var(--text-dim);font-weight:600;font-size:.85rem;letter-spacing:.1em}
.spinner{width:22px;height:22px;border:3px solid var(--line);border-top-color:var(--neon);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

#toast-container{position:fixed;top:1.2rem;right:1.2rem;z-index:300;display:flex;flex-direction:column;gap:.6rem;max-width:360px}
.toast{
  background:#fff;border:1px solid var(--line-strong);border-left:4px solid var(--neon);
  border-radius:12px;padding:.85rem 1.1rem;font-size:.9rem;color:var(--text-2);
  box-shadow:var(--shadow-lg);animation:toastIn .3s ease;
}
.toast strong{display:block;color:var(--text);margin-bottom:.15rem}
.toast.success{border-left-color:#22C55E}
.toast.error{border-left-color:#E5484D}
.toast.leaving{opacity:0;transform:translateX(12px);transition:all .3s}
@keyframes toastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}

/* ---------------- TABS ---------------- */
.tabs{display:flex;background:var(--bg-2);border-radius:999px;padding:.3rem;margin-bottom:1.4rem;border:1px solid var(--line)}
.tab{
  flex:1;border:0;background:transparent;border-radius:999px;padding:.65rem 1rem;
  font-weight:700;font-size:.9rem;color:var(--text-dim);transition:all var(--t-fast);
}
.tab.active{background:#fff;color:var(--neon);box-shadow:var(--shadow-md)}

/* ---------------- AUTH ---------------- */
.auth-wrap{max-width:480px;margin:0 auto;padding:3.5rem 1.4rem 5rem}
.auth-wrap h2{font-size:2.1rem;letter-spacing:-.03em;margin-bottom:.4rem}
.auth-wrap > p{color:var(--text-dim);margin-bottom:1.6rem;font-size:.95rem}
.auth-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.8rem;box-shadow:var(--shadow-md);
}
.divider{
  display:flex;align-items:center;gap:1rem;margin:1.3rem 0;
  color:var(--text-dim-2);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-switch{text-align:center;font-size:.9rem;color:var(--text-dim)}
.auth-switch span{display:block;margin-bottom:.5rem}
.auth-foot{text-align:center;margin-top:1rem;font-size:.88rem}

/* ---------------- SEÇÕES ---------------- */
.section-head{margin-bottom:2rem;display:flex;align-items:end;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.section-num{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--neon);font-weight:700;display:block;margin-bottom:.45rem}
.section-title-block h2{font-size:clamp(1.7rem,3.4vw,2.4rem);letter-spacing:-.03em}
.section-sub{font-size:.92rem;color:var(--text-dim);max-width:340px;text-align:right;line-height:1.55}

/* ---------------- CIDADES ---------------- */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.8rem}
.city-card{
  display:flex;flex-direction:column;gap:.15rem;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.15rem;
  transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);
}
.city-card:hover{border-color:var(--line-neon);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.city-card .city-name{font-family:var(--font-display);font-weight:700;color:var(--text);font-size:1.02rem;letter-spacing:-.01em}
.city-card .city-uf{font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--text-dim-2)}
.city-card .city-count{font-size:.8rem;color:var(--neon);font-weight:700;margin-top:.25rem}
.city-more{
  display:flex;align-items:center;justify-content:center;text-align:center;
  background:var(--bg-2);border:1.5px dashed var(--line-strong);border-radius:var(--radius);
  padding:1rem;font-weight:700;font-size:.9rem;color:var(--text-dim);
  transition:color var(--t-fast),border-color var(--t-fast);
}
.city-more:hover{color:var(--neon);border-color:var(--neon)}
.chips{display:flex;flex-wrap:wrap;gap:.55rem}
.chip{
  display:inline-flex;align-items:center;gap:.5rem;background:#fff;
  border:1px solid var(--line-strong);border-radius:999px;padding:.5rem 1.05rem;
  font-size:.86rem;font-weight:600;color:var(--text-2);
  transition:all var(--t-fast);
}
.chip:hover{border-color:var(--neon);color:var(--neon);background:var(--neon-soft)}
.chip .count{font-size:.72rem;color:var(--neon);font-weight:800}

/* ---------------- CARDS DE PERFIL ---------------- */
.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.3rem}
.profile-card{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;color:inherit;
  transition:box-shadow var(--t-mid),transform var(--t-mid),border-color var(--t-mid);
}
.profile-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--line-strong);color:inherit}
.profile-card .photo{
  position:relative;aspect-ratio:3/4;background-color:var(--bg-3);
  background-size:cover;background-position:center top;
  transition:filter var(--t-mid);
}
.profile-card:hover .photo{filter:saturate(1.06)}
.profile-card .photo::after{
  content:"";position:absolute;inset:auto 0 0 0;height:46%;
  background:linear-gradient(to top,rgba(20,4,12,.46),transparent);
  opacity:0;transition:opacity var(--t-mid);pointer-events:none;
}
.profile-card:hover .photo::after{opacity:1}
.tier-badge{
  position:absolute;top:.8rem;left:.8rem;z-index:2;
  font-size:.66rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  border-radius:999px;padding:.3rem .7rem;
}
.tier-badge.tier-vip{background:linear-gradient(135deg,#E8C788,#B98A4A);color:#3D2A0C}
.tier-badge.tier-top{background:var(--neon);color:#fff}
.card-badges{position:absolute;left:.8rem;bottom:.8rem;z-index:2;display:flex;gap:.4rem;flex-wrap:wrap}
.verify-badge{
  background:rgba(255,255,255,.94);color:var(--neon-deep);font-size:.68rem;font-weight:800;
  border-radius:999px;padding:.28rem .66rem;display:inline-flex;align-items:center;gap:.3rem;
}
.verify-badge::before{content:"✓";font-size:.75rem}
.verify-badge.audio::before{content:"🎙";font-size:.7rem}
.verify-badge.video::before{content:"▶";font-size:.6rem}
.online-indicator{
  position:absolute;top:.8rem;right:3.4rem;z-index:2;
  display:inline-flex;align-items:center;gap:.35rem;
  background:rgba(255,255,255,.94);border-radius:999px;padding:.28rem .7rem;
  font-size:.7rem;font-weight:800;color:#15803D;
}
.online-dot{width:7px;height:7px;border-radius:50%;background:#22C55E;display:inline-block;animation:pulse 2s infinite}
.fav-btn{
  position:absolute;top:.7rem;right:.7rem;z-index:3;width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.94);border:0;border-radius:50%;
  font-size:1.05rem;color:var(--text-dim);line-height:1;
  transition:color var(--t-fast),transform var(--t-fast);
}
.fav-btn:hover{transform:scale(1.12);color:var(--neon)}
.fav-btn.active{color:var(--neon)}
.audio-btn{
  position:absolute;bottom:.8rem;right:.8rem;z-index:3;width:34px;height:34px;
  border:0;border-radius:50%;background:var(--neon);color:#fff;font-size:.7rem;
  box-shadow:var(--glow);transition:transform var(--t-fast);
}
.audio-btn:hover{transform:scale(1.1)}
.audio-btn.playing{background:var(--neon-deep)}
.profile-card .body{padding:1rem 1.1rem 1.15rem;display:flex;flex-direction:column;gap:.35rem;flex:1}
.profile-card .head-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.profile-card .name{font-family:var(--font-display);font-weight:700;font-size:1.12rem;letter-spacing:-.015em;color:var(--text)}
.profile-card .rating{font-size:.8rem;font-weight:800;color:var(--acid);white-space:nowrap}
.profile-card .loc{font-size:.82rem;color:var(--text-dim);font-weight:500}
.profile-card .loc::before{content:"📍 ";font-size:.74rem}
.types{display:flex;flex-wrap:wrap;gap:.35rem;margin:.25rem 0}
.tag{
  background:var(--neon-soft);color:var(--neon-deep);font-size:.7rem;font-weight:700;
  border-radius:999px;padding:.26rem .6rem;letter-spacing:.02em;
}
.profile-card .price{
  margin-top:auto;font-family:var(--font-display);font-weight:800;font-size:1.05rem;
  color:var(--text);padding-top:.35rem;
}
.profile-card .price::first-letter{color:var(--neon)}

/* Skeleton */
.skeleton-card{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);background:#fff}
.skeleton{background:linear-gradient(100deg,var(--bg-2) 40%,var(--bg-3) 50%,var(--bg-2) 60%);background-size:200% 100%;animation:shimmer 1.3s infinite}
@keyframes shimmer{to{background-position:-200% 0}}
.skeleton-card .ph{aspect-ratio:3/4}
.skeleton-card .ln{height:14px;border-radius:6px;margin:.7rem 1rem}
.skeleton-card .ln:last-child{width:50%;margin-bottom:1rem}

/* ---------------- SERVIÇOS (type cards) ---------------- */
.types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:.9rem}
.type-card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.35rem 1.3rem 1.2rem;overflow:hidden;
  transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);
}
.type-card:hover{border-color:var(--line-neon);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.type-card .num{font-size:.68rem;font-weight:800;letter-spacing:.14em;color:var(--text-dim-2)}
.type-card h3{font-size:1.18rem;margin:.5rem 0 .2rem;letter-spacing:-.015em;transition:color var(--t-fast)}
.type-card:hover h3{color:var(--neon)}
.type-card p{font-size:.82rem;color:var(--text-dim)}
.type-card::after{
  content:"⟶";position:absolute;right:1.1rem;bottom:1rem;color:var(--neon);
  font-size:.95rem;opacity:0;transform:translateX(-6px);transition:all var(--t-fast);
}
.type-card:hover::after{opacity:1;transform:none}

/* ---------------- COMO FUNCIONA ---------------- */
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.how-step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.7rem 1.5rem;position:relative;
}
.how-step .how-n{
  font-family:var(--font-display);font-weight:800;font-size:2.6rem;line-height:1;
  color:var(--neon);opacity:.18;position:absolute;top:1.1rem;right:1.2rem;
}
.how-step h3{font-size:1.2rem;margin-bottom:.5rem;letter-spacing:-.015em}
.how-step p{font-size:.9rem;color:var(--text-dim)}

/* ---------------- CTA ANUNCIANTE ---------------- */
.cta-pro{
  background:linear-gradient(120deg,#2B0E1E 0%,#521233 55%,#8E1356 100%);
  border-radius:var(--radius-lg);padding:3rem 2.6rem;
  display:flex;align-items:center;justify-content:space-between;gap:2.5rem;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.cta-pro::after{
  content:"♥";position:absolute;right:1rem;top:-2.5rem;font-size:11rem;
  color:#fff;opacity:.05;transform:rotate(14deg);font-family:var(--font-display);
}
.cta-pro h2{color:#fff;font-size:clamp(1.5rem,3vw,2.1rem);letter-spacing:-.02em;margin-bottom:.5rem}
.cta-pro p{color:rgba(255,255,255,.75);font-size:.95rem;max-width:480px}
.cta-pro .btn{background:#fff;color:var(--neon-deep);box-shadow:none;flex:none}
.cta-pro .btn:hover{background:var(--bg-2);transform:translateY(-1px)}

/* ---------------- BUSCA ---------------- */
.search-page{max-width:var(--max);margin:0 auto;padding:2rem 1.4rem 4rem}
.search-page h1{font-size:1.7rem;letter-spacing:-.025em;margin-bottom:1.2rem}
.search-toolbar{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:.6rem;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:.6rem;box-shadow:var(--shadow-md);margin-bottom:1rem;
  position:sticky;top:64px;z-index:20;
}
.search-toolbar select{
  appearance:none;border:0;background:var(--bg-2);border-radius:10px;
  padding:.8rem 2.2rem .8rem .95rem;font:inherit;font-weight:600;font-size:.9rem;color:var(--text);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%23E61E7E' d='M0 0l5 6 5-6z'/></svg>");
  background-repeat:no-repeat;background-position:right .85rem center;cursor:pointer;min-width:0;
}
.results-meta{font-size:.86rem;color:var(--text-dim);font-weight:600;margin:0 0 1rem .2rem}
.sort-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:1.3rem}
.sort-label{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}
.sort-chip{
  background:#fff;border:1px solid var(--line-strong);border-radius:999px;
  padding:.45rem 1rem;font-size:.82rem;font-weight:600;color:var(--text-2);
  transition:all var(--t-fast);
}
.sort-chip:hover{border-color:var(--neon);color:var(--neon)}
.sort-chip.active{background:var(--neon);border-color:var(--neon);color:#fff}

/* ---------------- PERFIL ---------------- */
.profile-hero{
  max-width:var(--max);margin:0 auto;padding:2.2rem 1.4rem 3rem;
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:2.6rem;align-items:start;
}
.crumbs{font-size:.82rem;color:var(--text-dim);margin-bottom:.9rem;font-weight:600}
.crumbs a{color:var(--text-dim)}
.crumbs a:hover{color:var(--neon)}
.pg{position:sticky;top:84px}
.pg-main{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:zoom-in;
  background:var(--bg-3);box-shadow:var(--shadow-md);
}
.pg-main img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform var(--t-slow)}
.pg-main:hover img{transform:scale(1.025)}
.pg-count{
  position:absolute;bottom:.9rem;right:.9rem;background:rgba(20,4,12,.6);color:#fff;
  font-size:.74rem;font-weight:700;border-radius:999px;padding:.3rem .75rem;backdrop-filter:blur(4px);
}
.pg-strip{display:flex;gap:.55rem;margin-top:.7rem;overflow-x:auto;padding-bottom:.3rem}
.pg-thumb{
  flex:none;width:70px;height:88px;border-radius:10px;border:2px solid transparent;
  background-size:cover;background-position:center;cursor:pointer;opacity:.7;
  transition:opacity var(--t-fast),border-color var(--t-fast);
}
.pg-thumb:hover{opacity:1}
.pg-thumb.active{border-color:var(--neon);opacity:1}
.profile-info h1{font-size:clamp(1.9rem,3.6vw,2.7rem);letter-spacing:-.03em;display:flex;align-items:center;flex-wrap:wrap;gap:.2em}
.profile-info .headline{color:var(--text-dim);font-size:1rem;margin:.4rem 0 1.1rem;font-weight:500}
.profile-info .bio{color:var(--text-2);font-size:.97rem;margin:1.1rem 0 1.4rem}
.online-flag{
  display:inline-flex;align-items:center;gap:.45rem;background:#EFFBF3;border:1px solid #BBE7C9;
  color:#15803D;font-size:.8rem;font-weight:700;border-radius:999px;padding:.4rem .9rem;margin-bottom:.8rem;
}
.audio-strip{
  display:flex;align-items:center;gap:.9rem;background:var(--bg-2);
  border:1px solid var(--line);border-radius:12px;padding:.7rem 1rem;margin:.9rem 0;
}
.audio-strip-label{font-size:.78rem;font-weight:700;color:var(--text-dim);white-space:nowrap}
.audio-strip audio{width:100%;height:36px}
.verify-strip{display:flex;gap:.45rem;flex-wrap:wrap;margin:.6rem 0}
.verify-chip{
  font-size:.72rem;font-weight:700;border-radius:999px;padding:.32rem .75rem;
  background:var(--bg-2);color:var(--text-dim-2);border:1px solid var(--line);
}
.verify-chip.ok{background:#EFFBF3;color:#15803D;border-color:#BBE7C9}
.verify-chip.ok::before{content:"✓ "}
.meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.6rem;margin:1.2rem 0}
.meta-item{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem}
.meta-item .k{display:block;font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.15rem}
.meta-item .v{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--text)}
.profile-info .price{font-family:var(--font-display);font-weight:800;font-size:1.9rem;color:var(--neon);margin:1rem 0 .2rem;letter-spacing:-.02em}
.profile-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
.sticky-whatsapp{
  position:fixed;left:50%;bottom:1rem;transform:translateX(-50%);z-index:60;
  display:none;align-items:center;gap:.55rem;background:#1EBE5D;color:#fff;
  font-weight:800;font-size:.95rem;border-radius:999px;padding:.85rem 1.6rem;
  box-shadow:0 10px 30px rgba(30,190,93,.45);
}
.sticky-whatsapp svg{width:20px;height:20px}
.sticky-whatsapp:hover{color:#fff}
body.has-sticky-wpp{padding-bottom:4.5rem}
@media (max-width:900px){.sticky-whatsapp{display:flex}}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:200;background:rgba(20,4,12,.92);
  display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:12px;object-fit:contain}
.lb-close{position:absolute;top:1.2rem;right:1.4rem;background:none;border:0;color:#fff;font-size:1.6rem;opacity:.8}
.lb-close:hover{opacity:1}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;
  border:0;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:1.8rem;
  transition:background var(--t-fast);
}
.lb-nav:hover{background:var(--neon)}
.lb-prev{left:1.2rem}.lb-next{right:1.2rem}
.lb-count{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);color:#fff;font-size:.85rem;font-weight:700;opacity:.85}

/* ---------------- REVIEWS ---------------- */
.reviews-block{max-width:var(--max);margin:0 auto;padding:0 1.4rem 4rem}
.reviews-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem;padding-top:2.2rem;border-top:1px solid var(--line)}
.reviews-head h3{font-size:1.5rem;letter-spacing:-.02em}
.reviews-stats{font-size:.9rem;color:var(--text-dim);font-weight:600}
.reviews-stats b{color:var(--acid);font-size:1.05rem}
.review-list{display:flex;flex-direction:column;gap:.8rem}
.review-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.3rem}
.review-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.4rem}
.review-name{font-weight:700;font-size:.92rem}
.review-stars{color:var(--acid);font-size:.85rem;letter-spacing:.1em}
.review-comment{font-size:.92rem;color:var(--text-2)}
.review-form{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.5rem;margin-top:1.6rem}
.review-form h4{margin-bottom:1rem;font-size:1.1rem}
.rating-picker{display:flex;gap:.3rem;font-size:1.7rem;color:var(--text-dim-2);margin-bottom:.9rem}
.rating-picker button{background:none;border:0;font-size:inherit;color:inherit;transition:transform var(--t-fast)}
.rating-picker button.on{color:var(--acid)}
.rating-picker button:hover{transform:scale(1.15)}
.review-status{font-size:.72rem;font-weight:700;border-radius:999px;padding:.25rem .65rem}
.review-status-pending{background:#FFF7E6;color:#92600A}
.review-status-approved{background:#EFFBF3;color:#15803D}
.review-status-rejected{background:#FFF1F1;color:#9F1239}
.review-profile-link{display:flex;align-items:center;gap:.6rem;font-weight:600}
.review-profile-thumb{width:42px;height:42px;border-radius:10px;background-size:cover;background-position:center;flex:none}

/* ---------------- PLANOS ---------------- */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;align-items:stretch}
.plan{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2rem 1.7rem;display:flex;flex-direction:column;position:relative;
  transition:box-shadow var(--t-mid),transform var(--t-mid);
}
.plan:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.plan.featured{border:2px solid var(--neon);box-shadow:var(--glow-soft)}
.plan .primary-label,.plan .plan-flag{
  position:absolute;top:-0.85rem;left:50%;transform:translateX(-50%);
  background:var(--neon);color:#fff;font-size:.68rem;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;border-radius:999px;padding:.32rem .9rem;white-space:nowrap;
}
.plan h3{font-size:1.25rem;margin-bottom:.9rem;letter-spacing:-.015em}
.plan .price{font-family:var(--font-display);font-weight:800;font-size:2.5rem;color:var(--text);line-height:1;letter-spacing:-.03em}
.plan .price-suffix{font-size:.85rem;color:var(--text-dim);margin-bottom:1.2rem;display:block}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:.55rem;margin:1.1rem 0 1.6rem;font-size:.9rem;color:var(--text-2)}
.plan ul li::before{content:"✓ ";color:var(--neon);font-weight:800}
.plan .plan-cta{margin-top:auto}

/* ---------------- BANNERS ---------------- */
.signup-banner{
  background:var(--neon-soft);border:1px solid var(--line-neon);border-radius:var(--radius);
  padding:1.1rem 1.3rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;
}
.signup-banner strong{font-family:var(--font-display);font-size:1.05rem}
.signup-banner-sub{font-size:.86rem;color:var(--text-dim)}
.signup-banner-tag{background:var(--neon);color:#fff;font-size:.66rem;font-weight:800;border-radius:999px;padding:.25rem .6rem;letter-spacing:.1em;text-transform:uppercase}

/* ---------------- ÁREA DO MEMBRO ---------------- */
.member-wrap,.panel-wrap{max-width:var(--max);margin:0 auto;padding:2.2rem 1.4rem 4rem}
.member-layout,.panel-layout{display:grid;grid-template-columns:250px 1fr;gap:1.6rem;align-items:start}
.member-sidebar,.panel-sidebar{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.5rem 1.2rem;position:sticky;top:84px;
}
.member-avatar,.panel-avatar{
  width:68px;height:68px;border-radius:50%;overflow:hidden;margin:0 auto .8rem;
  border:2.5px solid var(--neon);display:flex;align-items:center;justify-content:center;
  background:var(--neon-soft);font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--neon);
}
.member-avatar img,.panel-avatar img{width:100%;height:100%;object-fit:cover}
.member-name,.panel-name{font-family:var(--font-display);font-weight:700;font-size:1.05rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:.4rem;flex-wrap:wrap}
.member-email,.panel-email{font-size:.78rem;color:var(--text-dim);text-align:center;margin:.2rem 0 1rem;word-break:break-all}
.member-stats-row{display:flex;justify-content:center;gap:1.4rem;margin-bottom:1.2rem;text-align:center}
.member-stats-row .v{font-family:var(--font-display);font-weight:800;font-size:1.2rem;display:block;color:var(--neon)}
.member-stats-row .k{font-size:.68rem;color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase;font-weight:700}
.member-nav,.panel-nav{display:flex;flex-direction:column;gap:.25rem}
.member-tab,.panel-tab{
  text-align:left;background:none;border:0;border-radius:10px;padding:.68rem .9rem;
  font-weight:600;font-size:.9rem;color:var(--text-2);transition:all var(--t-fast);
}
.member-tab:hover,.panel-tab:hover{background:var(--bg-2);color:var(--neon)}
.member-tab.active,.panel-tab.active{background:var(--neon-soft);color:var(--neon);font-weight:700}
.member-content,.panel-content{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2rem;min-height:420px;
}
.member-section-title{
  font-family:var(--font-display);font-weight:700;font-size:1.35rem;letter-spacing:-.02em;
  margin-bottom:1.4rem;padding-bottom:.7rem;border-bottom:2px solid var(--neon-soft);
}
.member-form{max-width:560px}
.member-count{font-size:.78rem;background:var(--neon);color:#fff;border-radius:999px;padding:.1rem .5rem;font-weight:800}
.member-user{margin-bottom:1.4rem}

/* Recently viewed strip */
.recent-section{margin:2.5rem 0 0}
.recent-strip{display:flex;gap:.9rem;overflow-x:auto;padding-bottom:.5rem}
.recent-card{flex:none;width:150px;border-radius:var(--radius);overflow:hidden;background:#fff;border:1px solid var(--line);transition:box-shadow var(--t-fast)}
.recent-card:hover{box-shadow:var(--shadow-md)}
.recent-photo{aspect-ratio:3/4;background-size:cover;background-position:center;background-color:var(--bg-3)}
.recent-info{padding:.6rem .7rem}
.recent-name{font-weight:700;font-size:.85rem;color:var(--text)}
.recent-loc{font-size:.72rem;color:var(--text-dim)}
.recent-price{font-size:.78rem;font-weight:800;color:var(--neon);margin-top:.2rem}

/* Assinatura */
.sub-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.5rem;margin-bottom:1rem}
.sub-plan{font-family:var(--font-display);font-weight:800;font-size:1.2rem}
.sub-tier{display:inline-block;background:var(--neon);color:#fff;font-size:.66rem;font-weight:800;border-radius:999px;padding:.22rem .6rem;letter-spacing:.1em;text-transform:uppercase;margin-left:.5rem}
.sub-price{color:var(--neon);font-weight:800}
.sub-dates,.sub-status{font-size:.84rem;color:var(--text-dim)}

/* ---------------- PAINEL DA PROFISSIONAL ---------------- */
.panel-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.8rem;margin-bottom:1.6rem}
.panel-kpi{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.1rem}
.panel-kpi .v{font-family:var(--font-display);font-weight:800;font-size:1.7rem;line-height:1.1}
.panel-kpi .k{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}
.panel-status-pill{display:inline-block;font-size:.7rem;font-weight:800;border-radius:999px;padding:.28rem .75rem;letter-spacing:.06em;text-transform:uppercase}
.panel-status-active{background:#EFFBF3;color:#15803D}
.panel-status-pending{background:#FFF7E6;color:#92600A}
.panel-status-suspended,.panel-status-canceled{background:#FFF1F1;color:#9F1239}
.panel-chart,.mini-chart{display:flex;align-items:flex-end;gap:4px;height:90px;margin:1rem 0}
.chart-bar,.rec-bar{flex:1;background:linear-gradient(to top,var(--neon),var(--neon-2));border-radius:4px 4px 0 0;min-height:3px;opacity:.85}
.panel-sub-status{font-size:.85rem;color:var(--text-dim)}

/* Fotos */
.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.8rem;margin-bottom:1.4rem}
.photo-item{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:3/4;border:1px solid var(--line)}
.photo-item img{width:100%;height:100%;object-fit:cover}
.photo-actions{position:absolute;inset:auto 0 0 0;display:flex;gap:.3rem;padding:.45rem;background:linear-gradient(to top,rgba(20,4,12,.65),transparent)}
.photo-actions button{flex:1;border:0;border-radius:8px;background:rgba(255,255,255,.92);font-size:.7rem;font-weight:700;padding:.35rem .2rem;color:var(--text-2)}
.photo-actions button:hover{background:#fff;color:var(--neon)}
.primary-label{position:absolute;top:.5rem;left:.5rem;background:var(--neon);color:#fff;font-size:.62rem;font-weight:800;border-radius:999px;padding:.22rem .55rem;letter-spacing:.08em;text-transform:uppercase}
.photo-upload-area{
  border:2px dashed var(--line-strong);border-radius:var(--radius);padding:2rem;text-align:center;
  color:var(--text-dim);font-size:.9rem;cursor:pointer;transition:all var(--t-fast);background:var(--bg-2);
}
.photo-upload-area:hover{border-color:var(--neon);color:var(--neon);background:var(--neon-soft)}
.avatar-upload{display:flex;align-items:center;gap:1.1rem;margin-bottom:1.4rem}
.avatar-preview{width:84px;height:84px;border-radius:50%;object-fit:cover;border:2.5px solid var(--neon)}
.avatar-btn{font-size:.84rem}

/* Recorder (áudio) */
.recorder-box{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.6rem;text-align:center}
.recorder-state{font-weight:700;color:var(--text-2);margin-bottom:.6rem}
.recorder-time{font-family:var(--font-display);font-weight:800;font-size:2rem;color:var(--neon)}
.recorder-viz{display:flex;align-items:center;justify-content:center;gap:3px;height:46px;margin:.8rem 0}
.recorder-viz span{width:4px;border-radius:2px;background:var(--neon);opacity:.7}
.recorder-controls,.recorder-actions{display:flex;justify-content:center;gap:.7rem;margin-top:1rem;flex-wrap:wrap}
.audio-current{display:flex;align-items:center;gap:.8rem;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:.8rem 1rem;margin-bottom:1.2rem}
.audio-label{font-size:.8rem;font-weight:700;color:var(--text-dim)}

/* Tipos / serviços checklist */
.types-checklist{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.55rem}
.type-check{
  display:flex;align-items:center;gap:.55rem;background:var(--bg-2);
  border:1.5px solid var(--line);border-radius:10px;padding:.7rem .9rem;
  font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--t-fast);
}
.type-check:hover{border-color:var(--line-neon)}
.type-check:has(input:checked){border-color:var(--neon);background:var(--neon-soft);color:var(--neon-deep)}
.type-check input{accent-color:var(--neon);width:17px;height:17px}

/* Verificação */
.verify-status-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.5rem;margin-bottom:1.3rem}
.verify-status-label{font-weight:800;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}
.verify-status-card.ok{background:#EFFBF3;border-color:#BBE7C9}
.verify-status-card.pending{background:#FFF7E6;border-color:#F3DFAE}

/* Disponibilidade online */
.online-options{display:flex;gap:.6rem;flex-wrap:wrap;margin:1rem 0}
.online-options button{border:1.5px solid var(--line-strong);background:#fff;border-radius:999px;padding:.55rem 1.2rem;font-weight:700;font-size:.86rem;color:var(--text-2)}
.online-options button:hover{border-color:var(--neon);color:var(--neon)}
.online-state-label{font-weight:700}
.online-status{display:inline-flex;align-items:center;gap:.4rem}

/* Onboarding tour */
.onb-card{
  position:fixed;inset:0;margin:auto;width:min(440px,92vw);height:fit-content;z-index:250;
  background:#fff;border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-lg);
  border:1px solid var(--line);text-align:center;
}
.onb-ic{font-size:2.4rem;margin-bottom:.6rem}
.onb-card h3{font-size:1.3rem;margin-bottom:.5rem}
.onb-card p{color:var(--text-dim);font-size:.92rem}
.onb-prog{display:flex;justify-content:center;gap:.4rem;margin:1.2rem 0}
.onb-prog .gdot{width:8px;height:8px;border-radius:50%;background:var(--line-strong)}
.onb-prog .gdot.on{background:var(--neon)}
.onb-actions{display:flex;justify-content:center;gap:.7rem;margin-top:1rem}

/* ---------------- AGE GATE + COOKIES ---------------- */
.age-gate{
  position:fixed;inset:0;z-index:400;background:rgba(36,16,25,.6);backdrop-filter:blur(14px);
  display:flex;align-items:center;justify-content:center;padding:1.2rem;
}
.age-card{
  background:#fff;border-radius:var(--radius-lg);max-width:430px;width:100%;
  padding:2.4rem 2.2rem;text-align:center;box-shadow:var(--shadow-lg);
}
.age-emoji{font-size:2.6rem;margin-bottom:.8rem}
.age-card h2{font-size:1.5rem;letter-spacing:-.02em;margin-bottom:.7rem}
.age-card p{color:var(--text-dim);font-size:.92rem;margin-bottom:.4rem}
.age-actions{display:flex;flex-direction:column;gap:.6rem;margin-top:1.4rem}
.cookie-banner{
  position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:90;max-width:560px;margin:0 auto;
  background:#fff;border:1px solid var(--line-strong);border-radius:var(--radius-lg);
  padding:1.1rem 1.3rem;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
}
.cookie-text{flex:1;font-size:.84rem;color:var(--text-2);min-width:220px}
.cookie-actions{display:flex;gap:.5rem}
.cookie-btn{border-radius:999px;padding:.55rem 1.2rem;font-weight:700;font-size:.84rem;border:0}
.cookie-btn.accept{background:var(--neon);color:#fff}
.cookie-btn.reject{background:var(--bg-3);color:var(--text-2)}

/* ---------------- SUPORTE / FAQ / LEGAL ---------------- */
.sup-wrap,.legal-wrap{max-width:760px;margin:0 auto;padding:3rem 1.4rem 5rem}
.sup-wrap h1,.legal-wrap h1{font-size:2rem;letter-spacing:-.03em;margin-bottom:.5rem}
.sup-sub{color:var(--text-dim);margin-bottom:2rem}
.sup-cta{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.8rem;text-align:center;margin-top:2.5rem}
.sup-cta h3{margin-bottom:.4rem}
.sup-cta p{color:var(--text-dim);font-size:.9rem;margin-bottom:1.1rem}
.legal-wrap h2{font-size:1.25rem;margin:1.8rem 0 .6rem}
.legal-wrap p,.legal-wrap li{font-size:.93rem;color:var(--text-2)}
.legal-wrap ul{padding-left:1.3rem;margin:.6rem 0}
.legal-updated{font-size:.8rem;color:var(--text-dim)}
.legal-back{display:inline-block;margin-bottom:1.4rem;font-weight:600;font-size:.88rem}

.chat-fab{
  position:fixed;right:1.3rem;bottom:1.3rem;z-index:80;width:54px;height:54px;
  border:0;border-radius:50%;background:var(--neon);color:#fff;font-size:1.4rem;
  box-shadow:var(--glow);transition:transform var(--t-fast);
}
.chat-fab:hover{transform:scale(1.08)}
.chat-panel{
  position:fixed;right:1.3rem;bottom:5.4rem;z-index:85;width:min(360px,92vw);
  background:#fff;border:1px solid var(--line-strong);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);display:none;flex-direction:column;overflow:hidden;max-height:70vh;
}
.chat-panel.open{display:flex}
.chat-head{display:flex;align-items:center;gap:.7rem;background:var(--neon);color:#fff;padding:.9rem 1.1rem}
.chat-head .dot{width:9px;height:9px;border-radius:50%;background:#7CFCAB;display:inline-block}
.chat-head small{display:block;opacity:.8;font-size:.72rem}
.chat-close{margin-left:auto;background:none;border:0;color:#fff;font-size:1rem;opacity:.85}
.chat-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;flex:1;background:var(--bg-2)}
.chat-opts{padding:.7rem 1rem 1rem;display:flex;flex-direction:column;gap:.4rem;background:var(--bg-2)}
.chat-opt{border:1px solid var(--line-neon);background:#fff;color:var(--neon-deep);border-radius:10px;padding:.55rem .8rem;font-size:.84rem;font-weight:600;text-align:left}
.chat-opt:hover{background:var(--neon-soft)}

/* "Em breve" (stubs ensaio / conteúdo 18+) */
.soon{max-width:620px;margin:0 auto;padding:4rem 1.4rem;text-align:center}
.soon-badge{display:inline-block;background:var(--neon-soft);color:var(--neon-deep);font-weight:800;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;border-radius:999px;padding:.4rem 1rem;margin-bottom:1.2rem}

/* ---------------- FOOTER ---------------- */
.site-footer{background:var(--bg-2);border-top:1px solid var(--line);padding:3.4rem 0 0;margin-top:2rem}
.site-footer .container{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.4rem;padding-bottom:2.6rem}
.site-footer .logo{margin-bottom:.7rem}
.site-footer p{font-size:.88rem;color:var(--text-dim);max-width:300px}
.site-footer h4{font-size:.76rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.85rem}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.site-footer ul a{color:var(--text-2);font-size:.9rem;font-weight:500}
.site-footer ul a:hover{color:var(--neon)}
.site-footer .legal{border-top:1px solid var(--line);padding:1.4rem;text-align:center}
.site-footer .legal p{font-size:.78rem;color:var(--text-dim);max-width:none;margin:0 auto .3rem}

/* ---------------- RESPONSIVO ---------------- */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:2rem}
  .profile-hero{grid-template-columns:1fr;gap:1.8rem}
  .pg{position:static}
  .how-grid{grid-template-columns:1fr}
  .plans-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .member-layout,.panel-layout{grid-template-columns:1fr}
  .member-sidebar,.panel-sidebar{position:static}
  .member-nav,.panel-nav{flex-direction:row;overflow-x:auto;padding-bottom:.3rem}
  .member-tab,.panel-tab{white-space:nowrap}
  .site-footer .container{grid-template-columns:1fr 1fr}
  .cta-pro{padding:2.2rem 1.6rem}
}
@media (max-width: 720px){
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:#fff;border-bottom:1px solid var(--line);padding:1rem 1.4rem;gap:.9rem;
    align-items:flex-start;box-shadow:var(--shadow-md);
  }
  .nav-links.open{display:flex}
  .mobile-menu{display:block}
  .nav-mobile-cta{display:block}
  .hero{padding:3.4rem 0 2.6rem}
  .hero-search{grid-template-columns:1fr;border-radius:16px}
  .hero-search button{padding:.95rem}
  .search-toolbar{grid-template-columns:1fr;position:static}
  .section-sub{text-align:left}
  .form-row{grid-template-columns:1fr}
  .member-content,.panel-content{padding:1.4rem}
  .auth-card{padding:1.4rem}
  .profile-info h1{font-size:1.8rem}
}

/* Checklist de requisitos de senha (injetado pelo app.js) */
.pw-reqs{list-style:none;display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem;font-size:.8rem;color:var(--text-dim)}
.pw-reqs li{display:flex;align-items:center;gap:.45rem;transition:color var(--t-fast)}
.pw-reqs li.ok{color:#16A34A}
.pw-reqs li.ok .pw-ic{color:#16A34A}
