:root {
  --bg:#080810;--bg2:#0a0a16;--card:rgba(255,255,255,.035);--border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.13);
  --fg:#f0f4ff;--muted:#566070;--muted2:#8fa3b8;--p:#a855f7;--p2:#c026d3;--p3:#f472b6;
  --grad:linear-gradient(135deg,#a855f7 0%,#c026d3 50%,#f472b6 100%);
  --grad-text:linear-gradient(90deg,#a855f7,#c084fc,#e879a8,#f9a8d4,#c084fc,#d8b4fe,#a855f7);
  --glow:0 0 24px rgba(168,85,247,.28),0 0 50px rgba(192,38,211,.13);
  --glow-sm:0 0 8px rgba(168,85,247,.14);--r:.5rem;
  --font-display:'Syne',sans-serif;--font-body:'Plus Jakarta Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;border:0}
html{background:var(--bg);color:var(--fg);font-family:var(--font-body);line-height:1.5;overflow-x:hidden;-webkit-text-size-adjust:100%;font-size:clamp(13px,3.5vw,16px)}
body{margin:0;overflow-x:hidden;-webkit-font-smoothing:antialiased;min-height:100vh;min-height:-webkit-fill-available;background:var(--bg)}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}
input{font-family:inherit;color:inherit;caret-color:var(--p)}
a{color:inherit;text-decoration:none}
img,svg{display:block}
*{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}
input,textarea{-webkit-user-select:text;user-select:text}

/* ── ANIMATIONS ── */
@keyframes gradAni{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes ripple{0%{transform:scale(0);opacity:.4}100%{transform:scale(5);opacity:0}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeOut{to{opacity:0;visibility:hidden}}
@keyframes stepIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}
@keyframes modalIn{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes modalOut{from{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(12px) scale(.96)}}
@keyframes couponPop{0%{opacity:0;transform:translateY(6px) scale(.95)}60%{transform:translateY(-2px) scale(1.02)}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes couponShake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-5px)}40%,80%{transform:translateX(5px)}}
@keyframes shakeInp{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-4px)}40%,80%{transform:translateX(4px)}}
@keyframes inputSuccessGlow{0%{box-shadow:0 0 0 0 rgba(74,222,128,.5)}100%{box-shadow:0 0 0 6px rgba(74,222,128,0)}}
@keyframes countPop{0%{opacity:0;transform:scale(.94)}100%{opacity:1;transform:scale(1)}}
@keyframes storeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes hFade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}


.gt{background:var(--grad-text);background-size:400% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 5s linear infinite}
/* scrollbar */
*{scrollbar-width:none;-ms-overflow-style:none}
*::-webkit-scrollbar{display:none}

/* ── CANVAS / BG ── */
#room3d{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.45}
.dot-grid{position:fixed;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,rgba(168,85,247,.04) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse 80% 80% at 50% 40%,black,transparent);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 40%,black,transparent)}
#hero-light{position:fixed;top:40%;left:50%;width:min(1000px,140vw);height:800px;transform:translate(-50%,-50%);background:radial-gradient(ellipse 50% 40% at 48% 38%,rgba(168,85,247,.13) 0%,transparent 60%),radial-gradient(ellipse 70% 60% at 52% 52%,rgba(192,38,211,.07) 0%,transparent 70%),radial-gradient(ellipse 40% 30% at 65% 25%,rgba(244,114,182,.05) 0%,transparent 55%);filter:blur(52px);pointer-events:none;z-index:2;transition:opacity .4s ease;will-change:transform}
#hero-light.hidden{opacity:0}
#noise-overlay{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.028;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:200px 200px}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:300;background:rgba(8,8,16,.82);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(255,255,255,.06);transition:opacity .3s,visibility .3s}
nav.hidden{opacity:0;visibility:hidden;pointer-events:none}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 24px;height:62px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-size:1.05rem;font-weight:700;letter-spacing:-.01em;cursor:pointer}
.nav-logo-ghost{font-size:1.2rem;display:inline-block;animation:float 5s ease infinite}
.nav-logo-dot{color:var(--p3)}
.nav-r{display:flex;align-items:center;gap:8px;margin-left:auto;padding-left:16px}
.nav-pill{font-family:var(--font-body);font-size:.6rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--p3);background:rgba(244,114,182,.08);border:1px solid rgba(244,114,182,.2);padding:3px 10px;border-radius:99px}
.btn-login{font-size:.8rem;font-weight:500;color:var(--muted2);padding:6px 14px;border-radius:var(--r);border:1px solid rgba(255,255,255,.08);transition:all .15s}
.btn-login:hover{border-color:rgba(255,255,255,.18);color:var(--fg);background:rgba(255,255,255,.04)}
.btn-register{font-size:.75rem;font-weight:600;background:var(--grad);color:#fff;padding:7px 13px;border-radius:var(--r);box-shadow:var(--glow-sm);transition:opacity .2s,transform .15s}
.btn-register:hover{opacity:.9;transform:translateY(-1px)}
.nav-avatar{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 10px 4px 4px;border-radius:99px;border:1px solid var(--border);background:rgba(255,255,255,.04);transition:all .15s}
.nav-avatar:hover{border-color:var(--border2);background:rgba(255,255,255,.07)}
.nav-av-circle{width:26px;height:26px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff;flex-shrink:0}
.nav-av-name{font-size:.75rem;font-weight:600;max-width:52px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── NAV MENU ── */
.nav-menu-btn{width:36px;height:36px;border-radius:var(--r);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:1px solid var(--border);cursor:pointer;transition:all .15s}
.nav-menu-btn:hover{border-color:var(--border2);background:rgba(255,255,255,.04)}
.nav-menu-btn span{display:block;width:16px;height:1.5px;background:var(--muted2);transition:all .25s;border-radius:2px}
.nav-menu-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-menu-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-menu-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav-dropdown{position:fixed;top:60px;left:0;right:0;z-index:250;background:rgba(10,10,18,.97);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);overflow:hidden;max-height:0;transition:max-height .32s cubic-bezier(.4,0,.2,1),opacity .25s,visibility .25s;opacity:0;visibility:hidden;pointer-events:none}
.nav-dropdown.open{max-height:680px;opacity:1;visibility:visible;pointer-events:all}
.menu-blur-overlay{position:fixed;inset:0;top:60px;z-index:249;background:rgba(8,8,15,.4);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .25s}
.menu-blur-overlay.on{opacity:1;pointer-events:all}
.nav-dropdown-inner{padding:14px 16px 20px}
.nav-drop-items{display:flex;flex-direction:column;gap:2px;margin-bottom:14px}
.nav-drop-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:.5rem;cursor:pointer;border:1px solid transparent;transition:all .15s}
.nav-drop-item:hover{background:rgba(255,255,255,.05);border-color:var(--border)}
.nav-drop-ico{width:36px;height:36px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--p)}
.nav-drop-name{font-size:.88rem;font-weight:600}
.nav-drop-divider{height:1px;background:var(--border);margin-bottom:16px}
.nav-drop-coupon{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:.5rem;padding:14px}
.nav-drop-coupon-title{font-size:.75rem;font-weight:600;color:var(--muted2);margin-bottom:10px;display:flex;align-items:center;gap:7px}
.coupon-input-wrap{display:flex;gap:8px}
.coupon-input{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r);padding:9px 12px;color:var(--fg);font-size:.82rem;font-family:inherit;transition:border-color .15s;text-transform:uppercase;letter-spacing:.05em}
.coupon-input::placeholder{color:rgba(148,163,184,.25);text-transform:none;letter-spacing:0}
.coupon-input:focus{outline:none;border-color:rgba(168,85,247,.4)}
.coupon-btn{padding:9px 16px;border-radius:var(--r);background:var(--grad);color:#fff;font-size:.78rem;font-weight:600;transition:opacity .15s;flex-shrink:0}
.coupon-btn:hover{opacity:.9}
.coupon-msg{font-size:.72rem;margin-top:8px;padding:7px 10px;border-radius:var(--r);display:none}
.coupon-msg.success{display:block;background:rgba(74,222,128,.08);color:#4ade80;border:1px solid rgba(74,222,128,.2);animation:couponPop .35s cubic-bezier(.34,1.56,.64,1) both}
.coupon-msg.error{display:block;background:rgba(248,113,113,.08);color:#f87171;border:1px solid rgba(248,113,113,.2);animation:couponShake .4s ease both}
.coupon-input.applied{animation:inputSuccessGlow .6s ease forwards;border-color:rgba(74,222,128,.5) !important}
.coupon-input.shake-inp{animation:shakeInp .4s ease;border-color:rgba(248,113,113,.5) !important}

/* ── PAGES ── */
.page{display:none !important;position:relative;z-index:2}
.page.active{display:block !important;animation:pageIn .22s ease both}
#page-home.active{display:flex !important;flex-direction:column}
#page-modules.active,#page-query.active,#page-results.active,#page-settings.active,#page-history.active,#page-store.active,#page-product.active{display:flex !important;flex-direction:column;align-items:center}
#page-store.active{animation:storeIn .25s cubic-bezier(.22,1,.36,1) both}

/* ── HERO ── */
.hero{min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;padding:60px 24px 40px;position:relative;overflow:hidden}
.hero-inner{position:relative;z-index:1;max-width:580px;width:100%;margin-top:-60px}
.hero-badge{display:inline-flex;align-items:center;gap:7px;font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--p3);background:rgba(244,114,182,.07);border:1px solid rgba(244,114,182,.18);padding:.3rem 1rem;border-radius:99px;margin-bottom:1rem;opacity:0;animation:hFade .5s ease .05s both;will-change:opacity;backface-visibility:hidden;transition:opacity .4s ease,margin .4s ease,max-height .4s ease,padding .4s ease;overflow:hidden;max-height:60px}
.hero-badge.hidden{opacity:0;max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0;border-width:0;pointer-events:none}
.hero-title{font-family:var(--font-body);font-size:clamp(2.2rem,7vw,3.8rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;color:var(--fg);margin-bottom:.8rem;opacity:0;animation:hFade .5s ease .18s both;transition:margin-top .4s ease}
.hero-sub{font-family:var(--font-display);font-size:.92rem;line-height:1.6;color:rgba(148,163,184,.78);max-width:360px;margin:0 auto 2.2rem;font-weight:300;letter-spacing:.01em;opacity:0;animation:hFade .5s ease .3s both;will-change:opacity;backface-visibility:hidden;transition:opacity .4s ease}
.hero-cta{display:flex;justify-content:center;margin-bottom:3.6rem;opacity:0;animation:hFade .5s ease .42s both}
.hero-stats{margin-top:1.8rem}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:0;opacity:0;animation:hFade .5s ease .55s both}
.hero-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:0 24px}
.hero-stat:not(:last-child){border-right:1px solid rgba(255,255,255,.08)}
.hero-stat-num{font-family:var(--font-body);font-size:1.5rem;font-weight:800;letter-spacing:-.03em;background:var(--grad-text);background-size:400% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 12s linear infinite}
.hero-stat-label{font-size:.6rem;color:rgba(148,163,184,.35);letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.btn-cta{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:10px;font-size:.9rem;font-weight:600;letter-spacing:.01em;background:var(--grad);color:#fff;padding:14px 36px;border-radius:.6rem;box-shadow:0 0 10px rgba(168,85,247,.11),0 0 20px rgba(192,38,211,.05),0 4px 24px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.15);transition:opacity .2s,transform .2s,box-shadow .2s}
.btn-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.12),transparent);pointer-events:none}
.btn-cta:hover{opacity:.93;transform:translateY(-2px);box-shadow:0 0 13px rgba(168,85,247,.16),0 8px 28px rgba(0,0,0,.45)}
.btn-cta:active{transform:translateY(0)}
.btn-cta .rip{position:absolute;border-radius:50%;background:rgba(255,255,255,.22);width:10px;height:10px;animation:ripple .6s ease-out forwards;pointer-events:none}
.btn-arrow{display:none}

#plans{position:relative;background:rgba(6,6,14,.3);border-top:1px solid rgba(255,255,255,.05);padding:52px 24px 60px;display:flex;flex-direction:column;align-items:center}
#plans::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(700px,100%);height:200px;background:radial-gradient(ellipse at 50% 0%,rgba(244,114,182,.06) 0%,rgba(168,85,247,.04) 45%,transparent 75%);z-index:0;pointer-events:none}
#plans>*{position:relative;z-index:1}
.plans-label{font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.4rem;display:flex;align-items:center;gap:6px;background:var(--grad-text);background-size:400% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 12s linear infinite}
.plans-label::before{content:'';width:14px;height:1px;background:var(--p);opacity:.5}
.plans-label::after{content:'';width:14px;height:1px;background:var(--p);opacity:.5}
.plans-title{font-family:var(--font-body);font-size:clamp(1.7rem,4vw,2.6rem);font-weight:800;letter-spacing:-.03em;text-align:center;margin-bottom:.35rem}
.plans-sub{font-family:var(--font-display);font-size:.82rem;color:rgba(148,163,184,.5);text-align:center;margin-bottom:2rem;font-weight:600;letter-spacing:.01em}

/* Plans grid - 1 col mobile, 2 tablet, 4 desktop */
.plans-carousel-wrap{width:100%;position:relative;overflow:hidden;z-index:3;mask-image:linear-gradient(to right,transparent 0%,black 4%,black 96%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 4%,black 96%,transparent 100%)}
.plans-grid-new{display:flex;flex-direction:row;align-items:stretch;gap:16px;overflow:visible;padding:8px 0 20px;cursor:grab;user-select:none;will-change:transform}
.plans-grid-new.dragging{cursor:grabbing}
.plans-grid-new .pc{flex:0 0 min(310px,86vw);min-width:0;transition:opacity .18s ease,transform .18s ease}
.plans-grid-new .pc:not(.pc-active){opacity:.7;transform:scale(.97) translateY(3px)}
.plans-grid-new .pc.pc-active{opacity:1!important;transform:scale(1) translateY(0)}
.plans-dots{display:flex;gap:6px;justify-content:center;margin-top:8px}
.plans-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.18);transition:all .2s;cursor:pointer}
.plans-dot.active{background:var(--p3);width:18px;border-radius:3px}

.pc{position:relative;background:rgba(255,255,255,.055);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.1);border-radius:1rem;padding:24px;transition:border-color .2s,transform .2s,box-shadow .2s;overflow:visible;box-shadow:0 4px 24px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.06);z-index:10}
.pc::before{content:'';position:absolute;inset:0;border-radius:1rem;background:linear-gradient(135deg,rgba(255,255,255,.04) 0%,transparent 60%);z-index:0;pointer-events:none}
.pc>*{position:relative;z-index:1}
.pc:hover{border-color:rgba(255,255,255,.18);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.4),0 0 0 1px rgba(168,85,247,.08),inset 0 1px 0 rgba(255,255,255,.08)}
.pc.feat{background:rgba(168,85,247,.12);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-color:rgba(168,85,247,.35)}
.pc.feat:hover{border-color:rgba(168,85,247,.55);box-shadow:0 16px 40px rgba(0,0,0,.4),0 0 24px rgba(168,85,247,.1)}
.pc.feat2{background:rgba(244,114,182,.09);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-color:rgba(244,114,182,.2)}
.pc.feat2:hover{border-color:rgba(244,114,182,.35);box-shadow:0 16px 40px rgba(0,0,0,.4),0 0 20px rgba(244,114,182,.08)}
.pc-rec-badge-inline{display:inline-flex;align-items:center;font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--grad);color:#fff;padding:3px 10px;border-radius:99px;white-space:nowrap}
.pc-tag{display:inline-flex;align-items:center;font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 9px;border-radius:99px;margin-bottom:10px}
.t-free{background:rgba(74,222,128,.1);color:#4ade80;border:1px solid rgba(74,222,128,.25)}
.t-starter{background:rgba(168,85,247,.12);color:#c084fc;border:1px solid rgba(168,85,247,.28)}
.t-pro{background:rgba(168,85,247,.15);color:#c084fc;border:1px solid rgba(168,85,247,.35)}
.t-premium{background:rgba(232,121,160,.12);color:var(--p3);border:1px solid rgba(232,121,160,.25)}
.pc-name{font-family:var(--font-body);font-size:1.1rem;font-weight:700;color:var(--fg);margin-bottom:4px}
.pc-price{font-family:var(--font-body);font-size:2.2rem;font-weight:800;letter-spacing:-.04em;line-height:1;background:var(--grad-text);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:2px}
.pc-price-free{font-family:var(--font-body);font-size:2.2rem;font-weight:800;letter-spacing:-.04em;line-height:1;color:#4ade80;margin-bottom:2px}
.pc-period{font-size:.72rem;color:var(--muted);margin-bottom:14px}
.pc-div{height:1px;background:var(--border);margin-bottom:14px}
.pc-features{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.pc-feature{display:flex;align-items:flex-start;gap:7px;font-size:.78rem;color:var(--muted2)}
.pc-check{flex-shrink:0;font-size:.7rem;margin-top:2px;background:var(--grad-text);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 4s ease infinite}
.pc-feature strong{color:var(--fg);font-weight:600}
.pc-btn{width:100%;padding:9px;border-radius:var(--r);font-size:.8rem;font-weight:600;border:1px solid var(--border2);color:var(--muted2);transition:all .15s}
.pc-btn:hover{border-color:rgba(168,85,247,.4);color:var(--p3);background:rgba(168,85,247,.06)}
.pc-btn:active{border-color:rgba(244,114,182,.5);color:var(--p3);background:rgba(244,114,182,.08)}
.pc-btn.primary{background:var(--grad);color:#fff;border:none;box-shadow:var(--glow-sm);transition:opacity .2s,transform .15s}
.pc-btn.primary:hover{opacity:.9;transform:translateY(-1px)}
.pc-detail{overflow:hidden;max-height:0;opacity:0;margin-top:0;border-top:0px solid var(--border);transition:max-height .2s ease,opacity .15s ease,margin-top .2s ease}
.pc-detail>*{padding-top:0;transition:padding-top .2s ease}
.pc-btn{position:relative;z-index:2}
.pd-mod-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px 8px;padding-top:4px}
.pm-item{display:flex;align-items:center;justify-content:space-between;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.04);gap:4px}
.pm-name{font-size:.7rem;color:var(--muted);flex:1}
.pm-val{font-size:.68rem;font-weight:700;flex-shrink:0}
.pm-val.yes{color:#4ade80;font-size:.76rem}
.pm-val.lim{color:var(--p3)}
.pm-val.no{color:rgba(255,255,255,.14);font-size:.76rem}
.pc-acquired{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;color:#4ade80;background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.2);padding:4px 12px;border-radius:99px;margin-bottom:8px}

/* plans fade */
.plans-drag-hint{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.65rem;color:rgba(255,255,255,.2);margin-top:10px;letter-spacing:.04em;user-select:none}

/* ── FAQ ── */
#faq{width:100%;background:transparent;border-top:1px solid rgba(255,255,255,.05)}
.faq-bar{display:flex;align-items:center;justify-content:space-between;padding:9px 24px;cursor:pointer;gap:12px;transition:background .15s}
.faq-bar:hover{background:rgba(255,255,255,.02)}
.faq-bar-left{display:flex;align-items:center;gap:7px}
.faq-bar-svg{color:#2e3d4a;flex-shrink:0}
.faq-bar-label{font-size:.65rem;font-weight:500;color:#2e3d4a;letter-spacing:.04em}
.faq-chevron{color:#2e3d4a;font-size:.55rem;transition:transform .3s cubic-bezier(.4,0,.2,1)}
#faq.open .faq-chevron{transform:rotate(180deg)}
.faq-panel{max-height:0;overflow:hidden;transition:max-height .38s cubic-bezier(.4,0,.2,1)}
/* max-height do painel é setado dinamicamente via JS para nunca cortar conteúdo */
.faq-scroll{padding:6px 24px 18px;display:flex;flex-direction:column;gap:6px}
.faq-item{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.055);border-radius:.6rem;overflow:hidden;cursor:pointer;transition:border-color .2s}
.faq-item:hover{border-color:rgba(255,255,255,.09)}
.faq-item.open{border-color:rgba(168,85,247,.2)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;font-size:.78rem;font-weight:500;color:var(--muted2);line-height:1.4}
.faq-icon{flex-shrink:0;width:16px;height:16px;border-radius:50%;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.52rem;color:var(--muted);transition:transform .25s,border-color .2s,color .2s;transform:rotate(45deg)}
.faq-item.open .faq-icon{transform:rotate(0deg);border-color:rgba(168,85,247,.3);color:var(--p)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .28s cubic-bezier(.4,0,.2,1)}
.faq-item.open .faq-a{max-height:600px} /* fallback alto — JS seta o valor real */
.faq-a-inner{padding:0 14px 13px;font-size:.74rem;color:var(--muted);line-height:1.65;border-top:1px solid rgba(255,255,255,.045);padding-top:10px;font-weight:300}

/* ── FOOTER ── */
footer{background:#0d0b16;border-top:1px solid rgba(168,85,247,.1);padding:22px 24px 24px}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-logo{display:flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;font-size:.9rem;letter-spacing:-.01em}
.footer-socials{display:flex;gap:8px}
.footer-icon{width:34px;height:34px;border-radius:var(--r);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .15s}
.footer-icon:hover{border-color:rgba(255,255,255,.14);color:var(--fg);background:rgba(255,255,255,.06)}
.footer-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.footer-copy{font-size:.72rem;color:#475569}
.footer-links{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.footer-sep{font-size:.68rem;color:rgba(255,255,255,.1)}
.footer-link{font-size:.68rem;color:#3a4a58;cursor:pointer;transition:color .15s}
.footer-link:hover{color:var(--muted)}
@media(max-width:600px){.footer-inner{flex-direction:column;align-items:center;text-align:center}.footer-right{align-items:center}}

/* ── MODULES ── */
#page-modules{padding:60px 20px 40px;min-height:100vh}
.page-head{text-align:center;padding:0 0 20px}
.page-head h2{font-family:var(--font-body);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:700;letter-spacing:-.025em;margin-bottom:4px}
.page-head p{font-size:.82rem;color:var(--muted);font-weight:300}
.mods-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%;max-width:700px}
@media(min-width:560px){.mods-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.mods-grid{grid-template-columns:repeat(4,1fr);max-width:860px}}
@media(min-width:1100px){.mods-grid{grid-template-columns:repeat(5,1fr);max-width:1000px}}
.mc{position:relative;overflow:hidden;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:.85rem;padding:18px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column}
.mc:hover{border-color:rgba(168,85,247,.35);background:rgba(168,85,247,.055);transform:translateY(-3px);box-shadow:0 6px 18px rgba(0,0,0,.25)}
.mc.soon{opacity:.4;cursor:default}.mc.soon .mc-ico,.mc.soon .mc-ico-wrap{background:rgba(255,255,255,.04)!important;border-color:rgba(255,255,255,.07)!important;color:var(--muted)!important}
.mc.soon:hover{transform:none;border-color:var(--border);background:var(--card)}
.mc.hot-mod{border-color:rgba(232,121,160,.22);background:rgba(232,121,160,.04)}
.mc.hot-mod:hover{border-color:rgba(232,121,160,.45);background:rgba(232,121,160,.08)}
.mc-soon-badge{position:absolute;top:9px;right:9px;font-size:.5rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:rgba(255,255,255,.06);color:var(--muted);border:1px solid var(--border);padding:2px 7px;border-radius:99px}
.mc-hot-badge{position:absolute;top:9px;right:9px;font-size:.52rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:var(--grad);color:#fff;padding:2px 7px;border-radius:99px}
.mc-ico{width:38px;height:38px;border-radius:.55rem;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:10px;flex-shrink:0;background:rgba(168,85,247,.08);border:1px solid rgba(168,85,247,.16);color:var(--p);transition:background .2s,border-color .2s}
.mc:hover .mc-ico{background:rgba(168,85,247,.14);border-color:rgba(168,85,247,.28)}
.mc-foto{border-color:rgba(244,114,182,.2);background:rgba(244,114,182,.03)}.mc-foto:hover{border-color:rgba(244,114,182,.42)!important;background:rgba(244,114,182,.07)!important}
.mc-foto:hover .mc-ico{background:rgba(244,114,182,.12)!important;border-color:rgba(244,114,182,.3)!important}
.mc-name{font-size:.86rem;font-weight:600;color:var(--fg);margin-bottom:2px}
.mc-desc{font-size:.68rem;color:var(--muted);line-height:1.4;margin-bottom:8px;flex:1;font-weight:300}
.mc-desc-foto{font-size:.68rem;color:rgba(168,85,247,.7);line-height:1.4;margin-bottom:8px;flex:1;font-weight:300}
.mc-link{font-size:.68rem;font-weight:600;color:var(--p);transition:gap .15s;margin-top:auto}
.mc.hot-mod .mc-link{color:var(--p3)}
.mc.soon{opacity:.22;cursor:default;filter:grayscale(.6)}.mc.soon .mc-ico,.mc.soon .mc-ico-wrap{background:rgba(255,255,255,.04)!important;border-color:rgba(255,255,255,.07)!important;color:var(--muted)!important}
.mc.soon:hover{transform:none;border-color:var(--border);background:rgba(255,255,255,.03);box-shadow:none}
.mods-grid .mc:nth-child(1){animation-delay:.03s}
.mods-grid .mc:nth-child(2){animation-delay:.06s}
.mods-grid .mc:nth-child(3){animation-delay:.09s}
.mods-grid .mc:nth-child(4){animation-delay:.12s}
.mods-grid .mc:nth-child(5){animation-delay:.15s}
.mods-grid .mc:nth-child(6){animation-delay:.18s}
.mods-grid .mc:nth-child(7){animation-delay:.21s}
.mods-grid .mc:nth-child(8){animation-delay:.24s}

/* ── QUERY ── */
#page-query{padding:60px 20px 40px;min-height:100vh}
.q-wrap{display:flex;flex-direction:column;align-items:center;width:100%;max-width:440px;padding-top:8px}
.q-ico{width:48px;height:48px;border-radius:.65rem;display:flex;align-items:center;justify-content:center;margin-bottom:8px;background:rgba(168,85,247,.1);border:1px solid rgba(168,85,247,.2);color:var(--p)}
.q-title{font-family:var(--font-body);font-size:1.2rem;font-weight:700;letter-spacing:-.025em;margin-bottom:3px}
.q-sub{font-size:.78rem;color:var(--muted);margin-bottom:14px;text-align:center;font-weight:300}
#fam-selector{display:none;gap:8px;margin-bottom:14px;width:100%}
.fam-opt{flex:1;padding:11px;border-radius:var(--r);font-size:.88rem;font-weight:600;background:var(--card);border:1px solid var(--border);color:var(--muted2);transition:all .15s;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.fam-opt:hover{border-color:var(--border2);color:var(--fg)}
.fam-opt.active{background:rgba(232,121,160,.1);border-color:rgba(232,121,160,.35);color:var(--p3)}
.q-box{width:100%;background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:20px}
.iw{position:relative;margin-bottom:10px}
.iw input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r);padding:12px 40px 12px 14px;color:var(--fg);font-size:.875rem;transition:all .15s}
.modal-input::placeholder{color:rgba(148,163,184,.25);font-weight:300}
.iw input::placeholder{color:rgba(148,163,184,.25);font-weight:300}
.coupon-input::placeholder{color:rgba(148,163,184,.25);font-weight:300;text-transform:none;letter-spacing:0}
.store-search::placeholder{color:rgba(148,163,184,.25)}
input::placeholder{color:rgba(148,163,184,.25)}
.iw input:focus{outline:none;border-color:rgba(168,85,247,.45);box-shadow:0 0 0 3px rgba(168,85,247,.07)}
.iw-ico{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#334155;font-size:.8rem;pointer-events:none}
.btn-search{width:100%;padding:12px;background:var(--grad);color:#fff;border-radius:var(--r);font-size:.875rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:7px;box-shadow:var(--glow-sm),0 0 30px rgba(168,85,247,.2);transition:opacity .15s,transform .15s,box-shadow .2s;position:relative;overflow:hidden}
.btn-search::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.12),transparent);pointer-events:none}
.btn-search:hover{opacity:.92;transform:translateY(-1px);box-shadow:var(--glow),0 0 40px rgba(168,85,247,.3)}

/* ── RESULTS ── */
#page-results{padding:60px 20px 80px;min-height:100vh}
.res-wrap{width:100%;max-width:640px;padding-top:8px}
.rc{background:rgba(255,255,255,.045);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:.75rem;overflow:hidden;margin-bottom:12px;animation:pageIn .3s ease both;transition:border-color .15s;box-shadow:0 4px 24px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.08)}
.rc:hover{border-color:var(--border2)}
.rc-head{display:flex;align-items:center;justify-content:center;padding:12px 18px;background:rgba(255,255,255,.025);border-bottom:1px solid var(--border)}
.rc-card-label{font-size:.85rem;font-weight:700;color:var(--fg);text-align:center;width:100%}
.rc-fields{padding:14px 18px;display:grid;grid-template-columns:1fr 1fr;gap:8px 14px}
.rf .rf-lbl{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px}
.rf .rf-val{font-size:.82rem;color:var(--fg);word-break:break-all;line-height:1.35}
.rf .rf-val a{color:var(--p3)}.rf .rf-val a:hover{text-decoration:underline}
.rf.wide{grid-column:1/-1}
@media(max-width:460px){.rc-fields{grid-template-columns:1fr}}
.res-err{background:var(--card);border:1px solid rgba(255,255,255,.07);border-radius:.75rem;padding:56px 24px;text-align:center;animation:pageIn .3s ease both}
.res-err h3{font-size:1rem;font-weight:600;margin:10px 0 6px}
.res-err p{font-size:.8rem;color:var(--muted)}
.whois-raw{width:100%;min-height:280px;background:rgba(0,0,0,.3);border:1px solid rgba(74,222,128,.15);border-radius:var(--r);color:#4ade80;font-family:'Courier New',monospace;font-size:.75rem;line-height:1.65;padding:14px 16px;resize:vertical;-webkit-user-select:text;user-select:text}
.res-mod-header{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 0 12px;text-align:center}
.res-mod-ico{width:52px;height:52px;border-radius:.75rem;background:rgba(168,85,247,.1);border:1px solid rgba(168,85,247,.2);display:flex;align-items:center;justify-content:center;color:var(--p)}
.res-mod-name{font-size:1rem;font-weight:700;color:var(--fg)}
.res-count{font-size:1rem;font-weight:700;color:var(--fg);text-align:center;margin-bottom:14px}
.rc-section-label{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p);padding:10px 18px 0;border-top:1px solid var(--border);margin-top:2px}
.rc-section-label:first-child{border-top:none}
.res-upgrade{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.1);border-radius:.75rem;padding:14px 16px;margin-top:16px}
.rc-locked-section{margin-top:4px;border-top:1px solid rgba(255,255,255,.06);padding:12px 18px}
.rc-locked-title{font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(168,85,247,.6);margin-bottom:8px;display:flex;align-items:center;gap:5px}
.rc-locked-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.rc-locked-field{display:flex;align-items:center;gap:7px;background:rgba(168,85,247,.04);border:1px solid rgba(168,85,247,.1);border-radius:.45rem;padding:7px 10px;cursor:pointer;transition:all .2s}
.rc-locked-field:hover{background:rgba(168,85,247,.09);border-color:rgba(168,85,247,.25)}
.rc-locked-lbl{font-size:.68rem;color:var(--muted);flex:1}
.rc-locked-val{font-size:.65rem;font-weight:600;color:rgba(168,85,247,.5);white-space:nowrap}
.rc-locked-ico{font-size:.7rem;flex-shrink:0;opacity:.5}
.res-upgrade-emoji{font-size:1.4rem;flex-shrink:0}
.res-upgrade-txt{font-size:.78rem;color:var(--muted2);line-height:1.5;flex:1}
.res-upgrade-txt strong{color:#f1f5f9;font-weight:600}
.res-upgrade-btn{flex-shrink:0;font-size:.75rem;font-weight:700;background:var(--grad);color:#fff;border:none;padding:8px 16px;border-radius:var(--r);transition:opacity .15s;white-space:nowrap;box-shadow:var(--glow-sm)}
.res-upgrade-btn:hover{opacity:.88}
.foto-placeholder-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 0;grid-column:1/-1}
.foto-placeholder{width:90px;height:120px;border-radius:.5rem;background:rgba(255,255,255,.04);border:1px dashed rgba(255,255,255,.12);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-size:.7rem}
.foto-download-btn{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:500;color:var(--muted);background:rgba(255,255,255,.05);border:1px solid var(--border);padding:7px 16px;border-radius:var(--r);transition:all .15s}
.foto-download-btn[disabled]{opacity:.5;cursor:not-allowed}

/* ── LOADING ── */
.ld{display:none;position:fixed;inset:0;z-index:500;background:rgba(6,6,14,.95);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:center;gap:22px}
.ld.on{display:flex;animation:fadeIn .18s ease}
.ld-ring{width:42px;height:42px;border-radius:50%;border:2px solid rgba(168,85,247,.12);border-top-color:var(--p);animation:spin .65s linear infinite}
.ld-steps{display:flex;flex-direction:column;gap:9px}
.ld-step{display:flex;align-items:center;gap:9px;font-size:.78rem;color:#1e293b;opacity:.4;transition:opacity .25s,color .25s}
.ld-step.on{color:var(--muted2);opacity:1;animation:stepIn .25s ease both}
.ld-step.done{color:#4ade80;opacity:1}
.step-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;background:currentColor}
.ld-step.on .step-dot{box-shadow:0 0 4px currentColor;animation:pulse 1.4s ease infinite}

/* ── MODALS ── */
.modal-overlay{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex;animation:fadeIn .18s ease}
.modal-overlay.closing{animation:fadeOut .2s ease forwards}
.modal.closing{animation:modalOut .2s ease forwards}
.modal{background:#100e14;border:1px solid rgba(244,114,182,.12);border-radius:.85rem;padding:32px 28px;width:100%;max-width:400px;box-shadow:0 32px 80px rgba(0,0,0,.6),0 8px 24px rgba(0,0,0,.4);position:relative;animation:modalIn .28s cubic-bezier(.34,1.56,.64,1)}
.modal-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:.375rem;display:flex;align-items:center;justify-content:center;font-size:.78rem;color:var(--muted);transition:color .15s}
.modal-close:hover{color:var(--fg)}
.modal-logo{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:.95rem;font-weight:700;margin-bottom:20px}
.modal-logo-dot{color:var(--p3)}
.modal h2{font-family:var(--font-body);font-size:1.3rem;font-weight:700;letter-spacing:-.025em;margin-bottom:5px}
.modal-sub{font-size:.8rem;color:var(--muted);margin-bottom:20px;line-height:1.55}
.modal-field{margin-bottom:13px}
.modal-label{font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted2);margin-bottom:6px;display:block}
.modal-input{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:11px 14px;color:var(--fg);font-size:.875rem;font-weight:300;transition:all .15s}
.modal-input::placeholder{color:rgba(148,163,184,.25);font-weight:300}
.modal-input:focus{outline:none;border-color:rgba(244,114,182,.35);box-shadow:0 0 0 3px rgba(244,114,182,.06);background:rgba(255,255,255,.05)}
.modal-input-wrap{position:relative}
.modal-input-wrap .modal-input{padding-right:40px}
.modal-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--muted);cursor:pointer;transition:color .15s;background:none;border:none}
.modal-eye:hover{color:var(--fg)}
.modal-hint{font-size:.7rem;color:var(--muted);line-height:1.5;margin-top:10px;padding:10px 12px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);border-radius:var(--r)}
.modal-submit{width:100%;margin-top:6px;padding:12px;background:var(--grad);color:#fff;border-radius:var(--r);font-size:.875rem;font-weight:600;transition:opacity .15s,transform .15s;position:relative;overflow:hidden}
.modal-submit::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.09),transparent);pointer-events:none}
.modal-submit:hover{opacity:.9;transform:translateY(-1px)}
.modal-footer{font-size:.75rem;color:var(--muted);text-align:center;margin-top:14px}
.modal-footer a{color:var(--p3);cursor:pointer;font-weight:500}
.modal-footer a:hover{text-decoration:underline}

/* ── BALÃO DE CONSULTAS — compacto ── */
.queries-balloon{width:100%;max-width:700px;margin-bottom:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:.65rem;padding:10px 14px;display:flex;align-items:center;gap:10px}
.qb-icon{width:28px;height:28px;border-radius:.4rem;background:rgba(168,85,247,.1);border:1px solid rgba(168,85,247,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--p)}
.qb-info{flex:1;min-width:0;display:flex;align-items:center;gap:10px}
.qb-label{font-size:.6rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);white-space:nowrap;flex-shrink:0}
.qb-bar-wrap{flex:1;background:rgba(255,255,255,.06);border-radius:99px;height:4px;overflow:hidden}
.qb-bar{height:100%;border-radius:99px;background:var(--grad);transition:width .6s cubic-bezier(.22,1,.36,1)}
.qb-bar.warn{background:linear-gradient(90deg,#f59e0b,#f97316)}
.qb-bar.danger{background:linear-gradient(90deg,#ef4444,#f97316)}
.qb-nums{font-size:.68rem;color:var(--muted2);white-space:nowrap;flex-shrink:0}
.qb-nums span{font-weight:600;color:var(--fg)}
.qb-info-btn{flex-shrink:0;width:22px;height:22px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.6rem;transition:all .15s;cursor:pointer;font-style:italic;font-family:var(--font-body)}
.qb-info-btn:hover{border-color:rgba(168,85,247,.3);color:var(--p);background:rgba(168,85,247,.06)}

/* ── MINI BALÃO NA TELA DE CONSULTA ── */
.q-mini-balloon{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;color:var(--muted2);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:99px;padding:4px 10px;margin-bottom:12px;transition:all .3s}
.q-mini-balloon .qmb-dot{width:6px;height:6px;border-radius:50%;background:var(--p);flex-shrink:0}
.q-mini-balloon.warn .qmb-dot{background:#f59e0b}
.q-mini-balloon.danger{border-color:rgba(248,113,113,.2);background:rgba(248,113,113,.06)}
.q-mini-balloon.danger .qmb-dot{background:#f87171}
.q-mini-balloon strong{color:var(--fg)}

/* ── CPF PRO BLOQUEADO ── */
.mc.locked{opacity:.22;cursor:default;filter:grayscale(.6);position:relative}
.mc.locked:hover{transform:none!important;border-color:var(--border)!important;background:rgba(255,255,255,.03)!important;box-shadow:none!important}
.mc-lock-badge{position:absolute;top:9px;right:9px;font-size:.5rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:rgba(168,85,247,.15);color:var(--p3);border:1px solid rgba(168,85,247,.3);padding:2px 7px;border-radius:99px;display:flex;align-items:center;gap:4px}

/* ── DOWNGRADE ANIMATION ── */
@keyframes downgradeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(1.1)}100%{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes downgradeOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(.85)}}

/* ── USAGE TOGGLE visível ── */
.usage-toggle-btn{display:flex;align-items:center;justify-content:space-between;width:100%;cursor:pointer;padding:12px 16px;border-bottom:1px solid var(--border)}
.usage-toggle-btn:hover .usage-toggle-label{color:var(--p3)}
.usage-toggle-label{font-size:.72rem;color:var(--p);font-weight:600;display:flex;align-items:center;gap:5px;transition:color .15s}
.usage-toggle-arrow{display:inline-block;transition:transform .3s cubic-bezier(.4,0,.2,1);font-size:.6rem}
.usage-toggle-arrow.open{transform:rotate(180deg)}
.qb-tooltip{position:fixed;z-index:9999;background:#10101e;border:1px solid rgba(255,255,255,.1);border-radius:.6rem;padding:12px 14px;font-size:.75rem;color:var(--muted2);box-shadow:0 12px 32px rgba(0,0,0,.6);max-width:220px;pointer-events:none;opacity:0;transition:opacity .15s;line-height:1.6}
.qb-tooltip.on{opacity:1}
.qb-tooltip strong{color:var(--fg)}

/* ── ANIMAÇÃO DE UPGRADE ── */
@keyframes planShake{0%,100%{transform:translate(-50%,-50%) rotate(0deg)}15%{transform:translate(-50%,-50%) rotate(-3deg) scale(1.02)}30%{transform:translate(-50%,-50%) rotate(3deg) scale(1.04)}45%{transform:translate(-50%,-50%) rotate(-4deg) scale(1.06)}60%{transform:translate(-50%,-50%) rotate(4deg) scale(1.08)}75%{transform:translate(-50%,-50%) rotate(-3deg) scale(1.05)}90%{transform:translate(-50%,-50%) rotate(2deg) scale(1.03)}}
@keyframes planCrack{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}40%{opacity:1;transform:translate(-50%,-50%) scale(1)}70%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.4)}}
@keyframes planExplode{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}30%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}100%{opacity:0;transform:translate(-50%,-50%) scale(2.5)}}
@keyframes planEmerge{0%{opacity:0;transform:translate(-50%,-50%) scale(.4) rotate(-8deg)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.12) rotate(2deg)}70%{transform:translate(-50%,-50%) scale(.96) rotate(-1deg)}100%{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(0deg)}}
@keyframes planGlowPulse{0%,100%{box-shadow:0 0 0 0 rgba(168,85,247,0)}50%{box-shadow:0 0 60px 20px rgba(168,85,247,.4),0 0 120px 40px rgba(192,38,211,.2)}}
@keyframes particleFly{0%{opacity:1;transform:translate(0,0) scale(1)}100%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(0)}}
@keyframes upgradeOverlayIn{from{opacity:0}to{opacity:1}}
@keyframes upgradeOverlayOut{from{opacity:1}to{opacity:0}}
@keyframes crackLine{0%{stroke-dashoffset:100;opacity:0}40%{opacity:1}100%{stroke-dashoffset:0;opacity:0}}

#upgrade-overlay{position:fixed;inset:0;z-index:9000;background:rgba(4,4,14,.97);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none}
#upgrade-overlay.on{pointer-events:all}
.upg-stage{position:relative;width:260px;height:260px}
.upg-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:180px;padding:22px 20px;border-radius:1rem;text-align:center;border:1px solid rgba(255,255,255,.12);background:#0d0d1e}
.upg-card-plan{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.upg-card-name{font-family:var(--font-body);font-size:1.5rem;font-weight:800;letter-spacing:-.03em;background:var(--grad-text);background-size:400% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 3s linear infinite}
.upg-card-sub{font-size:.7rem;color:var(--muted);margin-top:5px}
.upg-particles{position:absolute;inset:0;pointer-events:none}
.upg-particle{position:absolute;top:50%;left:50%;width:6px;height:6px;border-radius:50%;animation:particleFly .9s ease-out both}
.upg-label{position:absolute;bottom:-50px;left:50%;transform:translateX(-50%);font-size:.78rem;color:var(--muted2);white-space:nowrap;text-align:center;line-height:1.7}
.upg-label strong{color:var(--fg);display:block;font-size:1rem;font-family:var(--font-body);font-weight:700}
#upgrade-overlay canvas{position:absolute;inset:0;pointer-events:none}

/* ── BACK BTN ── */
.btn-back{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;color:var(--muted);transition:color .15s;padding:8px 0;margin-bottom:4px}
.btn-back:hover{color:var(--fg)}
.btn-back svg{width:13px;height:13px}
.res-back-btn{font-size:.82rem;font-weight:500;padding:10px 0;margin-bottom:8px}

/* ── SETTINGS ── */
#page-settings{padding:70px 20px 60px;min-height:100vh}
#page-history{padding:70px 20px 60px;min-height:100vh}
.hist-toggle-row{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:.6rem;padding:14px 16px;margin-bottom:20px}
.hist-toggle-info{flex:1}
.hist-toggle-title{font-size:.85rem;font-weight:600;margin-bottom:3px}
.hist-toggle-sub{font-size:.72rem;color:var(--muted);line-height:1.5}
.hist-toggle{position:relative;width:40px;height:22px;flex-shrink:0;margin-left:12px}
.hist-toggle input{opacity:0;width:0;height:0}
.hist-slider{position:absolute;inset:0;border-radius:99px;background:rgba(255,255,255,.1);border:1px solid var(--border);cursor:pointer;transition:background .2s}
.hist-slider::before{content:'';position:absolute;width:16px;height:16px;left:2px;top:2px;border-radius:50%;background:var(--muted);transition:transform .2s,background .2s}
.hist-toggle input:checked + .hist-slider{background:rgba(168,85,247,.3);border-color:rgba(168,85,247,.5)}
.hist-toggle input:checked + .hist-slider::before{transform:translateX(18px);background:var(--p)}
.hist-list-wrap{margin-top:4px}
.hist-month{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:18px 0 8px 2px}
.hist-item{display:flex;align-items:center;gap:10px;padding:11px 13px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:.55rem;margin-bottom:6px}
.hist-ico{width:32px;height:32px;border-radius:.4rem;background:rgba(168,85,247,.1);border:1px solid rgba(168,85,247,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--p);font-size:.7rem}
.hist-info{flex:1;min-width:0}
.hist-name{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hist-date{font-size:.65rem;color:var(--muted);margin-top:1px}
.hist-val{font-size:.78rem;font-weight:600;color:var(--muted2);flex-shrink:0;text-align:right}
.hist-val.free{color:#4ade80;font-size:.7rem}
.hist-val.paid{color:var(--p3)}
.hist-empty{text-align:center;padding:40px 20px;color:var(--muted);font-size:.82rem;line-height:1.7}
.hist-delete-btn{width:100%;margin-top:24px;padding:10px;border-radius:var(--r);font-size:.78rem;font-weight:600;color:#f87171;background:rgba(248,113,113,.06);border:1px solid rgba(248,113,113,.15);transition:all .15s}
.hist-delete-btn:hover{background:rgba(248,113,113,.1);border-color:rgba(248,113,113,.3)}
.hist-section-toggle{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--muted);cursor:pointer;margin-bottom:8px;user-select:none}
.hist-section-toggle svg{transition:transform .2s}
.hist-section-toggle.collapsed svg{transform:rotate(-90deg)}
.settings-wrap{width:100%;max-width:480px;padding-top:8px}
.settings-title{font-family:var(--font-body);font-size:1.2rem;font-weight:700;letter-spacing:-.025em;margin-bottom:20px}
.settings-card{background:var(--card);border:1px solid var(--border);border-radius:.75rem;overflow:hidden;margin-bottom:12px}
.settings-card-title{font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p);padding:12px 16px 8px;border-bottom:1px solid var(--border)}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid rgba(255,255,255,.04);gap:12px}
.settings-row:last-child{border-bottom:none}
.settings-row-label{font-size:.75rem;color:var(--muted);flex-shrink:0}
.settings-row-val{font-size:.82rem;font-weight:500;text-align:right;word-break:break-all}
.settings-plan-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:99px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.plan-badge-basico{background:rgba(74,222,128,.08);color:#4ade80;border:1px solid rgba(74,222,128,.22)}
.plan-badge-starter{background:rgba(168,85,247,.1);color:#c084fc;border:1px solid rgba(168,85,247,.28)}
.plan-badge-pro{background:rgba(192,38,211,.1);color:#e879f9;border:1px solid rgba(192,38,211,.28)}
.plan-badge-premium{background:rgba(244,114,182,.1);color:#f472b6;border:1px solid rgba(244,114,182,.28)}
.settings-progress-wrap{flex:1;display:flex;flex-direction:column;gap:4px;align-items:flex-end}
.settings-progress-bar{width:100%;max-width:160px;height:4px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.settings-progress-fill{height:100%;border-radius:99px;background:var(--grad);transition:width .4s ease}
.settings-progress-txt{font-size:.68rem;color:var(--muted)}
.btn-logout{width:100%;padding:12px;border-radius:var(--r);background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2);color:#f87171;font-size:.85rem;font-weight:600;transition:all .15s;margin-top:4px}
.btn-logout:hover{background:rgba(248,113,113,.15);border-color:rgba(248,113,113,.4)}
.set-msg{font-size:.72rem;padding:0;border-radius:.4rem;transition:all .2s;min-height:0}
.set-msg.err{color:#f87171;background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2);padding:8px 12px;animation:couponPop .3s ease both}
.modal-err{font-size:.78rem;color:#f87171;background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2);border-radius:.5rem;padding:8px 12px;margin-top:10px;text-align:center;animation:couponPop .3s ease both}
.set-msg.ok{color:#4ade80;background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.2);padding:8px 12px;animation:couponPop .3s ease both}

/* ── STORE ── */
#page-store{padding:0;align-items:center}
.store-hero-bar{width:100%;background:rgba(8,8,15,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 20px;height:60px;display:none;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;z-index:300;flex-shrink:0}
.store-subheader{width:100%;max-width:680px;padding:14px 24px 0;display:flex;align-items:center;justify-content:space-between}
.store-logo-store{background:linear-gradient(90deg,#b06ef3,#c084fc,#d8a8f0,#e89fc8,#c084fc,#b06ef3);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 6s linear infinite}
.store-count{font-size:.75rem;color:var(--muted)}
.store-count.pop{animation:countPop .22s ease both}
.store-search-row{display:flex;gap:10px;width:100%;max-width:680px;padding:12px 24px 0}
.store-search{flex:1;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:11px 16px;color:var(--fg);font-size:.875rem;font-family:inherit;transition:all .15s}
.store-search::placeholder{color:rgba(148,163,184,.25)}
.store-search:focus{outline:none;border-color:rgba(168,85,247,.4);background:rgba(255,255,255,.07)}
.store-filter-btn{display:flex;align-items:center;gap:7px;padding:11px 16px;border-radius:var(--r);background:rgba(255,255,255,.04);border:1px solid var(--border);font-size:.82rem;color:var(--muted2);transition:all .15s;white-space:nowrap}
.store-filter-btn:hover{border-color:var(--border2);color:var(--fg)}
.store-grid{display:flex;flex-direction:column;gap:14px;width:100%;max-width:680px;padding:14px 24px 60px}
.prod-card{background:#08081a;border:1px solid rgba(168,85,247,.14);border-radius:1rem;overflow:hidden;cursor:pointer;transition:all .3s;animation:pageIn .35s ease both;box-shadow:0 4px 24px rgba(0,0,0,.55)}
.prod-card:hover{border-color:rgba(168,85,247,.42);transform:translateY(-4px);box-shadow:0 14px 40px rgba(0,0,0,.6),0 0 24px rgba(168,85,247,.1)}
.prod-img{position:relative;width:100%;aspect-ratio:3/2;overflow:hidden;background:linear-gradient(135deg,rgba(168,85,247,.1),rgba(192,38,211,.06));display:flex;align-items:center;justify-content:center}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.prod-card:hover .prod-img img{transform:scale(1.06)}
.prod-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,8,15,.08) 0%,transparent 35%,transparent 55%,rgba(8,8,15,.72) 100%);pointer-events:none;z-index:1}
.prod-tag,.prod-fav{z-index:2}
.prod-img-placeholder{font-size:3rem;opacity:.18}
.prod-tag{position:absolute;top:10px;left:10px;font-size:.6rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:rgba(8,8,15,.82);color:var(--fg);padding:3px 10px;border-radius:99px;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08)}
.prod-fav{position:absolute;bottom:10px;right:10px;width:32px;height:32px;border-radius:50%;background:rgba(8,8,15,.75);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;backdrop-filter:blur(8px);transition:all .15s}
.prod-fav:hover{color:var(--p3);border-color:rgba(232,121,160,.35);transform:scale(1.1)}
.prod-fav.active svg{fill:#fbbf24;stroke:#fbbf24}
.prod-body{padding:18px}
.prod-name{font-family:var(--font-body);font-size:1rem;font-weight:700;color:var(--fg);margin-bottom:5px;line-height:1.35}
.prod-desc{font-size:.74rem;color:var(--muted);line-height:1.5;margin-bottom:13px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.prod-price-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.prod-price{font-family:var(--font-body);font-size:1.5rem;font-weight:800;letter-spacing:-.03em;background:var(--grad-text);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent}
.prod-price-old{font-size:.8rem;color:var(--muted);text-decoration:line-through}
.prod-discount-badge{font-size:.65rem;font-weight:700;background:rgba(168,85,247,.15);color:var(--p3);border:1px solid rgba(168,85,247,.25);padding:2px 8px;border-radius:99px}
.prod-buy-btn{width:100%;padding:12px;border-radius:var(--r);background:var(--grad);color:#fff;font-size:.88rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 0 16px rgba(168,85,247,.22);transition:opacity .15s,transform .15s;position:relative;overflow:hidden}
.prod-buy-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.1),transparent);pointer-events:none}
.prod-buy-btn:hover{opacity:.92;transform:translateY(-1px)}
#page-product{padding:0}
.pd-hero{width:100%;position:relative;overflow:hidden}
.pd-hero-back{position:absolute;top:14px;left:14px;z-index:4;display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:500;color:rgba(255,255,255,.9);background:rgba(8,8,15,.55);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);padding:6px 13px;border-radius:99px;transition:all .15s}
.pd-img{width:100%;aspect-ratio:4/3;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(168,85,247,.1),rgba(192,38,211,.06));position:relative}
.pd-img::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(to top,#06040e,transparent);pointer-events:none}
.pd-img img{width:100%;height:100%;object-fit:cover}
.pd-body{width:100%;max-width:680px;padding:20px 24px 60px}
.pd-tag{font-size:.6rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:rgba(8,8,15,.85);color:var(--fg);padding:3px 10px;border-radius:99px;border:1px solid rgba(255,255,255,.08);display:inline-block;margin-bottom:12px}
.pd-name{font-size:1.15rem;font-weight:700;line-height:1.3;color:var(--fg);margin-bottom:14px}
.pd-price-row{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.pd-price{font-size:1.6rem;font-weight:700;letter-spacing:-.03em;background:var(--grad-text);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent}
.pd-price-old{font-size:.85rem;color:var(--muted);text-decoration:line-through}
.pd-discount{font-size:.68rem;font-weight:700;background:var(--grad);color:#fff;padding:2px 9px;border-radius:99px}
.pd-buy-btn{width:100%;padding:14px;border-radius:var(--r);background:var(--grad);color:#fff;font-size:.95rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 0 20px rgba(168,85,247,.28);transition:opacity .15s,transform .15s;position:relative;overflow:hidden;margin-bottom:20px}
.pd-buy-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.1),transparent);pointer-events:none}
.pd-buy-btn:hover{opacity:.9;transform:translateY(-1px)}
.pd-sep{height:1px;background:var(--border);margin:20px 0}
.pd-section-title{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.pd-desc-text{font-size:.85rem;color:var(--muted2);line-height:1.7;white-space:pre-wrap}
.pd-badges{display:flex;gap:10px;flex-wrap:wrap}
.pd-badge{display:flex;align-items:center;gap:7px;padding:10px 14px;border-radius:.5rem;background:rgba(255,255,255,.04);border:1px solid var(--border);flex:1;min-width:100px}
.pd-badge svg{color:var(--p);flex-shrink:0}
.pd-badge-label{font-size:.7rem;font-weight:600;color:var(--muted2)}

/* ── TILT 3D ── */
.mc{transform-style:preserve-3d;transform:perspective(600px) rotateX(0) rotateY(0) scale(1);transition:transform .1s ease,border-color .2s,background .2s}
.mc:hover{transform:perspective(600px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) scale(1.02)}
.mc.soon:hover{transform:none}
.mc-ico{transition:transform .15s ease}
.mc:hover .mc-ico{transform:translateZ(14px) scale(1.12)}

@media(pointer:fine){
  *{cursor:none!important}
  #ghost-cursor{position:fixed;z-index:99999;pointer-events:none;transform:translate(-2px,-2px);transition:opacity .2s}
  #ghost-cursor svg{filter:drop-shadow(0 0 6px rgba(168,85,247,.8)) drop-shadow(0 0 12px rgba(244,114,182,.4))}
  #ghost-cursor.clicking svg{filter:drop-shadow(0 0 10px rgba(244,114,182,1)) drop-shadow(0 0 20px rgba(168,85,247,.6))}
  .cursor-trail-dot{position:fixed;z-index:99998;pointer-events:none;transform:translate(-50%,-50%);border-radius:50%;mix-blend-mode:screen}
}

/* ── COUNTER ── */

/* ── TILT 3D ── */
.mc{transform-style:preserve-3d;will-change:transform}
.mc .mc-ico{transition:transform .15s ease;transform:translateZ(0)}
.mc:hover .mc-ico{transform:translateZ(8px) scale(1.05)}

/* ── SPLASH ── */
#splash{position:fixed;inset:0;z-index:9999;background:#0b0b14;pointer-events:none;opacity:1;transition:opacity .4s cubic-bezier(.4,0,.2,1)}
#splash.fade{opacity:0}

/* ── RESPONSIVE ── */
@media(min-width:900px){
  .nav-inner{padding:0 40px}
  .hero-title{font-size:3rem}
  .hero-inner{max-width:680px}
  .hero-stat-num{font-size:1.75rem}
  .hero-stat{padding:0 32px}
  #plans{padding:52px 48px 80px}
  .plans-title{font-size:2.8rem}
  .plans-carousel-wrap{max-width:1100px}
  .plans-grid-new .pc{flex:0 0 280px}
  #page-modules{padding:60px 48px 60px}
  .mods-grid{grid-template-columns:repeat(5,1fr);max-width:1100px;gap:12px}
  #page-query{padding:60px 48px 60px}.q-wrap{max-width:520px}
  #page-results{padding:60px 48px 100px}.res-wrap{max-width:780px}
  .rc-fields{grid-template-columns:repeat(3,1fr)}
  .store-search-row{max-width:860px;padding:20px 0 0}
  .store-grid{max-width:860px;padding:18px 0 80px}
  footer{padding:18px 48px 20px}
  .modal{max-width:440px;padding:36px 32px}
  .btn-cta{font-size:1rem;padding:16px 44px}
}
@media(min-width:1280px){
  .hero-title{font-size:3.4rem}
  .hero-inner{max-width:720px}
  .mods-grid{grid-template-columns:repeat(6,1fr);max-width:1200px}
}
@media(max-width:480px){
  .nav-inner{padding:0 16px}.nav-pill{display:none}
  .hero-title{font-size:2rem}
  .rc-fields{grid-template-columns:1fr}
  .hero-stat-num{font-size:1.2rem}
  .hero-stat{padding:0 14px}
}

/* ── CARTEIRA DIGITAL ── */
#page-wallet{padding:70px 20px 60px;min-height:100vh;align-items:center}
.wallet-wrap{width:100%;max-width:420px}
.wallet-profile{display:flex;flex-direction:column;align-items:center;padding:28px 20px 24px;background:var(--card);border:1px solid var(--border);border-radius:1rem;margin-bottom:16px;position:relative;overflow:hidden}
.wallet-profile::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(168,85,247,.12),transparent 70%);pointer-events:none}
.wallet-avatar{width:72px;height:72px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:800;color:#fff;margin-bottom:12px;flex-shrink:0;overflow:hidden;border:2px solid rgba(255,255,255,.1);box-shadow:0 0 20px rgba(168,85,247,.25)}
.wallet-avatar img{width:100%;height:100%;object-fit:cover}
.wallet-name{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;background:var(--grad-text);background-size:400% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 4s linear infinite;margin-bottom:4px}
.wallet-plan{font-size:.68rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-weight:500}
.wallet-balance{margin-top:20px;text-align:center}
.wallet-balance-label{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.wallet-balance-val{font-size:2.4rem;font-weight:800;letter-spacing:-.04em;background:var(--grad-text);background-size:400% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 4s linear infinite;line-height:1}
.wallet-balance-sub{font-size:.72rem;color:var(--muted);margin-top:4px}
.wallet-buy-btn{width:100%;padding:14px;background:var(--grad);color:#fff;border-radius:var(--r);font-size:.92rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--glow-sm),0 0 28px rgba(168,85,247,.22);transition:opacity .15s,transform .15s;margin-top:16px}
.wallet-buy-btn:hover{opacity:.9;transform:translateY(-1px)}
.wallet-empty{text-align:center;padding:24px 20px;background:var(--card);border:1px solid var(--border);border-radius:1rem;margin-bottom:16px}
.wallet-empty p{font-size:.82rem;color:var(--muted);margin-bottom:16px;line-height:1.6}
/* avatar nas configs */
.settings-avatar-wrap{display:flex;align-items:center;gap:14px;padding:14px 16px}
.settings-avatar{width:54px;height:54px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden;border:2px solid rgba(255,255,255,.08)}
.settings-avatar img{width:100%;height:100%;object-fit:cover}
.settings-avatar-info{flex:1}
.settings-avatar-name{font-size:.88rem;font-weight:600;color:var(--fg);margin-bottom:2px}
.settings-avatar-change{font-size:.72rem;color:var(--p3);cursor:pointer;transition:opacity .15s}
.settings-avatar-change:hover{opacity:.75}
#page-upgrade{padding:70px 20px 40px;min-height:100vh;align-items:center}
.upgrade-header{text-align:center;margin-bottom:24px;width:100%;max-width:700px}
.upgrade-header h2{font-family:var(--font-body);font-size:clamp(1.2rem,3vw,1.7rem);font-weight:700;letter-spacing:-.025em;margin-bottom:6px}
.upgrade-header p{font-size:.82rem;color:var(--muted);font-weight:300}
.upgrade-back-btn{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;font-weight:600;color:var(--p3);background:rgba(244,114,182,.08);border:1px solid rgba(244,114,182,.2);padding:8px 16px;border-radius:99px;transition:all .15s;margin-top:20px}
.upgrade-back-btn:hover{background:rgba(244,114,182,.14);border-color:rgba(244,114,182,.35)}

/* ── CONFIRM LOGOUT ── */
.confirm-overlay{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.25);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);align-items:center;justify-content:center;padding:20px;animation:fadeIn .18s ease}
.confirm-overlay.open{display:flex}
.confirm-box{background:#09091a;border:1px solid rgba(255,255,255,.1);border-radius:.85rem;padding:28px 24px;width:100%;max-width:320px;text-align:center;animation:modalIn .28s cubic-bezier(.34,1.56,.64,1);box-shadow:0 24px 60px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04)}
.confirm-box h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.confirm-box p{font-size:.8rem;color:var(--muted);margin-bottom:20px;line-height:1.55}
.confirm-btns{display:flex;gap:10px}
.confirm-btns button{flex:1;padding:10px;border-radius:var(--r);font-size:.82rem;font-weight:600;transition:all .15s}
.confirm-cancel{background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--muted2)}
.confirm-cancel:hover{border-color:var(--border2);color:var(--fg)}
.confirm-logout{background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.25);color:#f87171}
.confirm-logout:hover{background:rgba(248,113,113,.2)}
#page-credits-info{padding:60px 20px 40px;min-height:100vh;align-items:center}
.cinfo-wrap{width:100%;max-width:420px}

/* hero */
.cinfo-hero{text-align:center;padding:20px 0 22px;position:relative}
.cinfo-s-wrap{display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.cinfo-s-ring{width:60px;height:60px;border-radius:50%;border:1px solid rgba(168,85,247,.2);display:flex;align-items:center;justify-content:center;position:relative}
.cinfo-s-ring::before{content:'';position:absolute;inset:-1px;border-radius:50%;border:1px solid transparent;background:linear-gradient(135deg,rgba(168,85,247,.4),rgba(244,114,182,.15)) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;pointer-events:none}
.cinfo-hero-label{font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;background:var(--grad-text);background-size:400% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 5s linear infinite;margin-bottom:8px}
.cinfo-hero h2{font-family:var(--font-body);font-size:1.5rem;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:8px}
.cinfo-hero p{font-size:.8rem;color:var(--muted);line-height:1.6;max-width:280px;margin:0 auto}

/* cards */
.cinfo-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.cinfo-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:.85rem;padding:14px 16px;display:flex;align-items:flex-start;gap:14px;cursor:default;transition:border-color .25s,background .25s,transform .25s,box-shadow .25s;transform-style:preserve-3d;will-change:transform;opacity:0;transform:translateY(16px);animation:cinfoIn .45s ease both}
.cinfo-card:nth-child(1){animation-delay:.05s}
.cinfo-card:nth-child(2){animation-delay:.13s}
.cinfo-card:nth-child(3){animation-delay:.21s}
@keyframes cinfoIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.cinfo-card:hover{border-color:rgba(168,85,247,.22);background:rgba(168,85,247,.04);box-shadow:0 8px 24px rgba(0,0,0,.25),0 0 0 1px rgba(168,85,247,.05)}
.cinfo-card-num{font-family:var(--font-display);font-size:2rem;font-weight:800;line-height:1;letter-spacing:-.04em;background:var(--grad-text);background-size:400% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 8s linear infinite;flex-shrink:0;width:44px;padding-top:0}
.cinfo-card-title{font-size:.86rem;font-weight:700;color:var(--fg);margin-bottom:2px;letter-spacing:-.01em}
.cinfo-card-desc{font-size:.74rem;color:var(--muted);line-height:1.55}

/* price row */
.cinfo-price-row{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:.65rem;padding:11px 16px;margin-bottom:14px;opacity:0;animation:cinfoIn .45s ease .28s both;overflow:visible}
.cinfo-price-from{font-size:.72rem;color:var(--muted)}
.cinfo-price-val{font-family:var(--font-body);font-size:1rem;font-weight:800;letter-spacing:-.025em;background:var(--grad-text);background-size:400% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 6s linear infinite;padding:2px 0;display:inline-block}

/* buy btn */
.cinfo-buy-btn{width:100%;padding:13px;background:var(--grad);color:#fff;border-radius:var(--r);font-size:.92rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 0 10px rgba(168,85,247,.12);transition:opacity .15s,transform .15s,box-shadow .2s;opacity:0;animation:cinfoIn .45s ease .34s both}
.cinfo-buy-btn:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 0 22px rgba(168,85,247,.22)}
.cinfo-buy-btn:active{transform:translateY(0)}
/* botão ciano */
.hero-orbit-2::after{background:var(--p2)}
.hero-orbit-3::after{background:var(--p3);width:4px;height:4px;right:-2px}
.credits-balloon{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:99px;padding:5px 12px 5px 9px;cursor:pointer;transition:border-color .2s,background .2s;color:var(--muted);font-size:.7rem;font-weight:600;letter-spacing:.01em}
.credits-balloon:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.13)}
.credits-balloon svg{opacity:.4;flex-shrink:0}
.credits-balloon.has-balance{border-color:rgba(168,85,247,.2)}
.credits-balloon.has-balance span{background:var(--grad-text);background-size:400% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradAni 3s linear infinite}
.credits-balloon.has-balance svg{opacity:.7;stroke:url(#credGrad)}
/* página de compra */
#page-credits{padding:70px 20px 60px;min-height:100vh;align-items:center}
.credits-wrap{width:100%;max-width:480px}
.credits-title{font-family:var(--font-body);font-size:1.3rem;font-weight:700;letter-spacing:-.025em;margin-bottom:4px}
.credits-sub{font-size:.82rem;color:var(--muted);margin-bottom:24px;line-height:1.55}
.credits-mod-tag{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-weight:600;background:rgba(168,85,247,.08);color:var(--p3);border:1px solid rgba(168,85,247,.2);padding:4px 12px;border-radius:99px;margin-bottom:20px}
.credits-qty-wrap{background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:20px;margin-bottom:16px}
.credits-qty-label{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.credits-qty-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.credits-qty-btn{width:36px;height:36px;border-radius:var(--r);border:1px solid rgba(168,85,247,.25);background:rgba(168,85,247,.06);font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;color:var(--p3)}
.credits-qty-btn:hover{border-color:rgba(6,182,212,.6);background:rgba(168,85,247,.1)}
.credits-qty-num{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r);padding:10px 14px;color:var(--fg);font-size:1.1rem;font-weight:700;text-align:center}
.credits-presets{display:flex;gap:8px;flex-wrap:wrap}
.credits-preset{flex:1;min-width:60px;padding:8px 6px;border-radius:var(--r);border:1px solid var(--border);background:rgba(255,255,255,.03);font-size:.72rem;font-weight:600;color:var(--muted2);transition:all .15s;text-align:center;cursor:pointer}
.credits-preset:hover{border-color:rgba(168,85,247,.25);color:var(--p3)}
.credits-preset.active{border-color:rgba(168,85,247,.45);background:rgba(168,85,247,.08);color:var(--fg)}
.credits-summary{background:rgba(168,85,247,.05);border:1px solid rgba(168,85,247,.18);border-radius:.75rem;padding:18px;margin-bottom:16px}
.credits-summary-row{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;padding:5px 0}
.credits-summary-row+.credits-summary-row{border-top:1px solid rgba(255,255,255,.05);padding-top:10px;margin-top:5px}
.credits-summary-label{color:var(--muted2)}
.credits-summary-val{font-weight:700;color:var(--fg)}
.credits-summary-val.green{color:#4ade80}
.credits-summary-val.big{font-size:1.2rem;color:var(--p3)}
.credits-discount{font-size:.62rem;font-weight:700;background:rgba(74,222,128,.12);color:#4ade80;border:1px solid rgba(74,222,128,.25);padding:2px 8px;border-radius:99px}
.credits-buy-btn{width:100%;padding:14px;background:var(--grad);color:#fff;border-radius:var(--r);font-size:.95rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 0 8px rgba(168,85,247,.8);transition:opacity .15s,transform .15s;position:relative;overflow:hidden}
.credits-buy-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.1),transparent);pointer-events:none}
.credits-buy-btn:hover{opacity:.9;transform:translateY(-1px)}
/* banner smart */
/* balão de créditos pequeno */
.csb-pill{display:inline-flex;align-items:center;gap:8px;border-radius:99px;padding:6px 12px 6px 8px;font-size:.72rem;font-weight:600;animation:slideUp .2s ease both;position:relative;cursor:default}
.csb-pill.normal{background:rgba(168,85,247,.08);border:1px solid rgba(168,85,247,.2);color:var(--muted2)}
.csb-pill.low{background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.25);color:#fbbf24}
.csb-pill.zero{background:rgba(248,113,113,.06);border:1px solid rgba(248,113,113,.18);color:#fca5a5}
.csb-pill-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.csb-pill.normal .csb-pill-dot{background:var(--p3)}
.csb-pill.low .csb-pill-dot{background:#fbbf24;box-shadow:0 0 5px rgba(251,191,36,.6);animation:pulse 1.2s infinite}
.csb-pill.zero .csb-pill-dot{background:#f87171;box-shadow:0 0 5px rgba(248,113,113,.6);animation:pulse .8s infinite}
.csb-pill-lbl{flex:1}
.csb-pill-btn{font-size:.68rem;font-weight:700;background:var(--grad);color:#fff;padding:3px 10px;border-radius:99px;margin-left:4px;transition:opacity .15s;white-space:nowrap}
.csb-pill-btn:hover{opacity:.85}
.csb-pill-close{font-size:.75rem;color:var(--muted);padding:2px 4px;margin-left:2px;border-radius:3px;transition:color .15s;line-height:1}
.csb-pill-close:hover{color:var(--fg)}
#modulesCreditsBanner{margin-bottom:10px}
/* mini confirm fechar */
.csb-confirm-overlay{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.25);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);align-items:center;justify-content:center;padding:20px}
.csb-confirm-overlay.open{display:flex}
.csb-confirm-box{background:#09091a;border:1px solid rgba(255,255,255,.1);border-radius:.75rem;padding:22px 20px;max-width:280px;width:100%;text-align:center;animation:modalIn .25s cubic-bezier(.34,1.56,.64,1);box-shadow:0 24px 60px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04)}
.csb-confirm-box p{font-size:.82rem;color:var(--muted2);margin-bottom:16px;line-height:1.55}
.csb-confirm-box small{font-size:.68rem;color:var(--muted);display:block;margin-top:8px}
@keyframes creditsPop{0%{transform:scale(1)}30%{transform:scale(1.18)}60%{transform:scale(.94)}100%{transform:scale(1)}}
@keyframes creditsFloat{0%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:0;transform:translateY(-40px) scale(.8)}}
.credits-spend-anim{position:fixed;z-index:9999;pointer-events:none;font-size:.85rem;font-weight:700;color:var(--p3);animation:creditsFloat .9s ease forwards}

/* ── SCROLL FADE IN ── */
.scroll-fade.visible{opacity:1;transform:translateY(0)}

/* ── SELEÇÃO DE TEXTO ── */
/* permite selecionar preços, texto do FAQ e valores de resultado */
.pc-price,.pc-price-free,.faq-a-inner,.rf .rf-val,.whois-raw,.pd-desc-text,.prod-price,
.rc-card-label,.rc-fields,.rf,.rf-lbl,.rf-val,.res-count,.res-mod-name,.rc-section-label{
  -webkit-user-select:text;user-select:text
}
/* ════════════════════════════════════════════════════
   ── BADGE NO MENU DROPDOWN ──
════════════════════════════════════════════════════ */
.nav-drop-badge {
  font-size:.52rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  background:rgba(74,222,128,.12);color:#4ade80;border:1px solid rgba(74,222,128,.25);
  padding:2px 7px;border-radius:99px;margin-left:4px;vertical-align:middle;
}

/* ════════════════════════════════════════════════════
   ── CHAT DE SUPORTE ──
════════════════════════════════════════════════════ */
@keyframes chatMsgIn {
  from { opacity:0; transform:translateY(10px) scale(.95); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
@keyframes chatWarnIn { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:translateY(0)} }
@keyframes chatPulse  { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.85)} }

#page-chat { padding:0; overflow:hidden; }
.chat-wrap {
  display:flex;flex-direction:column;height:100vh;max-width:680px;margin:0 auto;
  position:relative;
}

/* header */
.chat-header {
  display:flex;align-items:center;gap:12px;padding:16px 20px 14px;
  background:rgba(8,8,16,.92);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;
  padding-top:max(16px, env(safe-area-inset-top));
}
.chat-header .btn-back { flex-shrink:0; }
.chat-header-info { flex:1; }
.chat-header-title { font-family:var(--font-display);font-size:.95rem;font-weight:700;letter-spacing:-.01em; }
.chat-header-status { display:flex;align-items:center;gap:6px;font-size:.65rem;color:#4ade80;margin-top:1px; }
.chat-status-dot {
  width:6px;height:6px;border-radius:50%;background:#4ade80;
  animation:chatPulse 2s ease infinite;
}
.chat-header-ghost { font-size:1.4rem; }

/* mensagens */
.chat-messages {
  flex:1;overflow-y:auto;padding:20px 16px;display:flex;flex-direction:column;gap:12px;
}

/* msg de boas-vindas (sistema) */
.chat-system-msg {
  display:flex;align-items:flex-start;gap:10px;
  background:rgba(168,85,247,.06);border:1px solid rgba(168,85,247,.14);
  border-radius:.75rem;padding:14px;animation:chatMsgIn .4s ease both;
}
.chat-system-ico { font-size:1.3rem;flex-shrink:0;margin-top:1px; }
.chat-system-text { flex:1; }
.chat-system-text strong { font-size:.78rem;font-weight:700;color:var(--p3);display:block;margin-bottom:4px; }
.chat-system-text p { font-size:.82rem;color:var(--muted2);line-height:1.55; }
.chat-system-time { font-size:.65rem;color:var(--muted);margin-top:6px;display:block; }

/* linhas de mensagem */
.chat-msg-row { display:flex;align-items:flex-end;gap:8px;max-width:85%; }
.chat-msg-row.own { align-self:flex-end;flex-direction:row-reverse; }

/* balão de mensagem */
.chat-bubble {
  padding:10px 13px;border-radius:1rem;font-size:.83rem;line-height:1.55;
  position:relative;word-break:break-word;max-width:100%;
}
.chat-bubble.own {
  background:var(--grad);color:#fff;border-bottom-right-radius:.25rem;
  box-shadow:0 2px 12px rgba(168,85,247,.2);
}
.chat-bubble.ghost {
  background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--fg);
  border-bottom-left-radius:.25rem;
}
.chat-bubble-time {
  font-size:.58rem;opacity:.6;margin-left:8px;vertical-align:bottom;white-space:nowrap;
}

/* avatar do usuário */
.chat-ghost-ico { font-size:1.1rem;flex-shrink:0;margin-bottom:4px; }
.chat-avatar-wrap {
  width:32px;height:32px;border-radius:50%;flex-shrink:0;cursor:pointer;
  position:relative;overflow:visible;margin-bottom:4px;
}
.chat-avatar-wrap:hover { transform:scale(1.08); }
.chat-avatar-img { width:100%;height:100%;border-radius:50%;object-fit:cover; }
.chat-avatar-initial {
  width:32px;height:32px;border-radius:50%;background:var(--grad);
  display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:#fff;
}
.chat-avatar-ring { display:none; }
.chat-avatar-crown {
  position:absolute;top:-9px;left:50%;transform:translateX(-50%);
  font-size:.65rem;pointer-events:none;
}

/* popover de perfil */
.chat-profile-popover {
  position:absolute;bottom:90px;right:16px;
  background:#0d0d20;border:1px solid rgba(255,255,255,.1);border-radius:.85rem;
  padding:16px;min-width:180px;z-index:50;
  box-shadow:0 16px 40px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s,transform .2s,visibility .2s;
  transform:translateY(6px) scale(.97);
}
.chat-profile-popover.open {
  opacity:1;visibility:visible;pointer-events:all;transform:translateY(0) scale(1);
}
.cpp-avatar {
  width:48px;height:48px;border-radius:50%;margin:0 auto 10px;
  background:var(--grad);display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;font-weight:700;color:#fff;overflow:hidden;
  box-shadow:0 0 0 3px rgba(168,85,247,.3);
}
.cpp-name { text-align:center;font-weight:700;font-size:.88rem;margin-bottom:4px; }
.cpp-plan { text-align:center;font-size:.7rem;font-weight:600; }
.cpp-close {
  position:absolute;top:8px;right:10px;font-size:.75rem;color:var(--muted);
  cursor:pointer;transition:color .15s;padding:4px;
}
.cpp-close:hover { color:var(--fg); }

/* area de input */
.chat-input-area {
  display:flex;align-items:flex-end;gap:10px;padding:12px 16px;
  background:rgba(8,8,16,.92);backdrop-filter:blur(20px);
  border-top:1px solid var(--border);
  padding-bottom:max(12px, env(safe-area-inset-bottom));
}
.chat-user-avatar {
  width:32px;height:32px;border-radius:50%;flex-shrink:0;cursor:pointer;
  background:var(--grad);display:flex;align-items:center;justify-content:center;
  overflow:hidden;transition:transform .15s;
}
.chat-user-avatar:hover { transform:scale(1.06); }
.chat-input-wrap {
  flex:1;background:rgba(255,255,255,.05);border:1px solid var(--border);
  border-radius:.75rem;padding:10px 12px 8px;position:relative;
  transition:border-color .15s;
}
.chat-input-wrap:focus-within { border-color:rgba(168,85,247,.35); }
.chat-input {
  width:100%;background:transparent;border:none;outline:none;color:var(--fg);
  font-family:var(--font-body);font-size:.83rem;line-height:1.5;resize:none;
  min-height:20px;max-height:120px;overflow-y:auto;
  -webkit-user-select:text;user-select:text;
}
.chat-input-counter {
  font-size:.6rem;color:var(--muted);text-align:right;margin-top:3px;
}
.chat-send-btn {
  width:40px;height:40px;border-radius:50%;background:var(--grad);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 10px rgba(168,85,247,.25);transition:opacity .15s,transform .15s;
}
.chat-send-btn:hover { opacity:.9;transform:scale(1.05); }
.chat-send-btn:active { transform:scale(.96); }

/* aviso de rate limit */
.chat-rate-warn {
  display:none;font-size:.72rem;color:#fbbf24;background:rgba(251,191,36,.07);
  border:1px solid rgba(251,191,36,.2);border-radius:.4rem;padding:7px 12px;
  margin:0 16px 6px;text-align:center;
}

/* ════════════════════════════════════════════════════
   ── PÁG DE PÓS-COMPRA (THANK YOU) ──
════════════════════════════════════════════════════ */
@keyframes tyIconIn  { 0%{opacity:0;transform:scale(.4) rotate(-30deg)} 70%{transform:scale(1.15) rotate(5deg)} 100%{opacity:1;transform:scale(1) rotate(0)} }
@keyframes tyTextIn  { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }
@keyframes tyQIn     { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

#page-thankyou { overflow:hidden; }
.ty-wrap {
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:40px 24px;position:relative;
}
.ty-canvas { position:fixed;inset:0;z-index:0;pointer-events:none; }
.ty-content { position:relative;z-index:1;text-align:center;max-width:380px; }
.ty-icon {
  font-size:3rem;margin-bottom:16px;display:block;
  animation:tyIconIn .6s cubic-bezier(.34,1.56,.64,1) .1s both;
}
.ty-title {
  font-family:var(--font-display);font-size:1.7rem;font-weight:800;letter-spacing:-.02em;
  margin-bottom:8px;animation:tyTextIn .45s ease .3s both;
  background:var(--grad-text);background-size:400% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:tyTextIn .45s ease .3s both, gradAni 5s linear infinite;
}
.ty-sub {
  font-size:.88rem;color:var(--muted2);line-height:1.6;
  animation:tyTextIn .45s ease .45s both;margin-bottom:28px;
}
.ty-question { animation:tyQIn .4s ease .7s both; }
.ty-q-text { font-size:.85rem;color:var(--muted2);margin-bottom:14px;line-height:1.5; }
.ty-btns { display:flex;flex-direction:column;gap:10px; }
.ty-btn {
  padding:13px 20px;border-radius:var(--r);font-size:.88rem;font-weight:600;
  transition:all .15s;cursor:pointer;
}
.ty-btn-no {
  background:var(--grad);color:#fff;
  box-shadow:0 4px 20px rgba(168,85,247,.25);
}
.ty-btn-no:hover { opacity:.9;transform:translateY(-1px); }
.ty-btn-yes {
  background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--muted2);
}
.ty-btn-yes:hover { border-color:var(--border2);color:var(--fg);background:rgba(255,255,255,.07); }
.ty-q-done {
  font-size:.88rem;color:#4ade80;padding:12px;
  background:rgba(74,222,128,.07);border:1px solid rgba(74,222,128,.2);border-radius:.5rem;
}

/* ════════════════════════════════════════════════════
   ── CARDS DE PLANOS — ANIMAÇÃO SUAVIZADA ──
════════════════════════════════════════════════════ */
.pc-detail {
  overflow:hidden;
  max-height:0;
  opacity:0;
  /* Removida qualquer animação de bounce — só fade + height suave */
  transition:max-height .35s cubic-bezier(.4,0,.2,1), opacity .28s ease;
}
.pc-detail.open {
  opacity:1;
  /* max-height setado via JS */
}

/* Suaviza tilt dos cards */
.mc { transition:transform .18s ease, box-shadow .18s ease; }
.mc:hover { transform:translateY(-2px); }

/* ── GRADIENTE BLOB (efeito bolha circular) ── */
@keyframes blobShift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.btn-cta,
.btn-register,
.coupon-btn,
.btn-search,
.modal-submit,
.prod-buy-btn,
.pd-buy-btn,
.wallet-buy-btn,
.cinfo-buy-btn,
.credits-buy-btn,
.chat-send-btn,
.ty-btn-no,
.csb-pill-btn,
.res-upgrade-btn,
.btn-trocar-foto {
  background: linear-gradient(135deg, #7c2ff7, #a855f7, #c026d3, #e879f9, #f472b6, #c026d3, #a855f7);
  background-size: 300% 300%;
  animation: blobShift 14s ease-in-out infinite;
}

/* Botão Assinar dos planos — mais lento e sutil */
.pc-btn.primary {
  background: linear-gradient(135deg, #7c2ff7, #a855f7, #c026d3, #e879f9, #f472b6, #c026d3, #a855f7);
  background-size: 300% 300%;
  animation: blobShift 22s ease-in-out infinite;
}

/* Botão Trocar foto arredondado */
.btn-trocar-foto {
  border-radius: 99px !important;
  padding: 5px 14px !important;
  font-size: .72rem !important;
}

/* Avatar spacer — mantém alinhamento quando avatar não aparece */
.chat-avatar-spacer {
  width:32px;height:1px;flex-shrink:0;
}

/* ── ANIMAÇÃO TROCAR FOTO ── */
@keyframes avatarSwap {
  0%   { opacity:1; transform:scale(1); }
  30%  { opacity:0; transform:scale(.85); }
  60%  { opacity:0; transform:scale(1.1); }
  100% { opacity:1; transform:scale(1); }
}
.avatar-swapping {
  animation: avatarSwap .45s cubic-bezier(.34,1.56,.64,1) both;
}

html{height:-webkit-fill-available}

/* ── FILTRO STORE — fade out ── */
@keyframes filterFadeOut {
  from { opacity:1; transform:translateY(0) scale(1); }
  to   { opacity:0; transform:translateY(-6px) scale(.97); pointer-events:none; }
}
#storeFilterDropdown { display:none; }

/* ── FILTER OVERLAY POPUP ── */
@keyframes filterPopupIn {
  from { opacity:0; transform:translateY(18px) scale(.97); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
@keyframes filterPopupOut {
  from { opacity:1; transform:translateY(0) scale(1); }
  to   { opacity:0; transform:translateY(12px) scale(.97); }
}
.filter-overlay {
  position: fixed;
  inset: 0;
  z-index: 399;
  background: rgba(8,8,16,.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
}
.filter-overlay.on {
  opacity: 1;
  pointer-events: all;
}
.filter-popup {
  position: fixed;
  bottom: -120%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 400;
  width: min(340px, 92vw);
  background: #0d0d1e;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 1.1rem 1.1rem 1.1rem 1.1rem;
  overflow: hidden;
  box-shadow: 0 -4px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(168,85,247,.08);
  transition: bottom .32s cubic-bezier(.34,1.12,.64,1), opacity .25s ease;
  opacity: 0;
}
.filter-popup.on {
  bottom: 32px;
  opacity: 1;
  animation: filterPopupIn .32s cubic-bezier(.34,1.12,.64,1) both;
}
.filter-popup-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 18px 12px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.filter-popup-title {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(148,163,184,.5);
}
.filter-popup-close {
  font-size: .85rem;
  color: var(--muted);
  padding: 4px 8px;
  border-radius: var(--r);
  transition: color .15s;
}
.filter-popup-close:hover { color: var(--fg); }
.filter-popup-options {
  padding: 8px 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.filter-option {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  text-align: left;
  padding: 12px 14px;
  font-size: .88rem;
  font-weight: 500;
  color: var(--muted2);
  background: none;
  border: 1px solid transparent;
  border-radius: .6rem;
  transition: all .15s;
  cursor: pointer;
}
.filter-option:hover {
  background: rgba(255,255,255,.04);
  border-color: var(--border);
  color: var(--fg);
}
.filter-option.active {
  color: var(--p3);
  background: rgba(244,114,182,.06);
  border-color: rgba(244,114,182,.18);
}
.filter-option svg { flex-shrink: 0; opacity: .7; }

/* ── PREÇOS COM DESCONTO DE CADASTRO ── */
.pc-price-wrap {
  display: flex;
  flex-direction: column;
  gap: 1px;
  margin-bottom: 2px;
}
.pc-price-guest {
  font-size: .85rem;
  font-weight: 600;
  color: var(--muted);
  text-decoration: line-through;
  text-decoration-color: rgba(248,113,113,.5);
  letter-spacing: -.01em;
}
.pc-discount-tag {
  display: inline-flex;
  align-items: center;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .04em;
  color: #4ade80;
  background: rgba(74,222,128,.08);
  border: 1px solid rgba(74,222,128,.2);
  border-radius: 99px;
  padding: 2px 8px;
  margin-top: 3px;
  width: fit-content;
}

/* ── BANNER FLUTUANTE DESCONTO ── */
@keyframes discBannerIn {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes discBannerOut {
  from { opacity:1; transform:translateY(0); }
  to   { opacity:0; transform:translateY(10px); }
}
.discount-banner {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 350;
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(10,10,22,.95);
  border: 1px solid rgba(74,222,128,.3);
  border-radius: 99px;
  padding: 10px 18px;
  font-size: .78rem;
  font-weight: 500;
  color: var(--muted2);
  white-space: nowrap;
  cursor: pointer;
  box-shadow: 0 4px 24px rgba(0,0,0,.5), 0 0 16px rgba(74,222,128,.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .4s ease, transform .4s ease;
}
.discount-banner.visible {
  opacity: 1;
  pointer-events: all;
  animation: discBannerIn .4s ease both;
}
.discount-banner svg { color: #4ade80; flex-shrink: 0; }
.discount-banner strong { color: #4ade80; }
.discount-banner-cta {
  margin-left: 6px;
  font-weight: 700;
  color: var(--p3);
  font-size: .75rem;
}

/* ── FILTRO DE PREÇO — NOVO POPUP ── */
.filter-popup-title {
  font-size: .98rem;
  font-weight: 700;
  color: var(--fg);
  letter-spacing: normal;
  text-transform: none;
}
.filter-popup-clearbtn {
  font-size: .78rem;
  font-weight: 500;
  color: var(--muted2);
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  border-radius: 99px;
  padding: 5px 14px;
  transition: all .15s;
}
.filter-popup-clearbtn:hover { color: var(--fg); border-color: var(--border2); }
.filter-popup-body {
  padding: 18px 18px 4px;
}
.filter-section-label {
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(148,163,184,.45);
  margin-bottom: 8px;
}
.filter-price-input {
  width: 100%;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: .75rem;
  padding: 14px 16px;
  font-size: .95rem;
  color: var(--fg);
  font-family: inherit;
  outline: none;
  transition: border-color .15s;
  -webkit-user-select: text;
  user-select: text;
}
.filter-price-input::placeholder { color: rgba(148,163,184,.3); }
.filter-price-input:focus { border-color: rgba(168,85,247,.4); }
.filter-sort-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-bottom: 4px;
}
.filter-sort-chip {
  font-size: .75rem;
  font-weight: 600;
  color: var(--muted2);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 99px;
  padding: 6px 14px;
  transition: all .15s;
  cursor: pointer;
}
.filter-sort-chip:hover { color: var(--fg); border-color: var(--border2); }
.filter-sort-chip.active {
  color: var(--p3);
  background: rgba(244,114,182,.08);
  border-color: rgba(244,114,182,.3);
}
.filter-popup-footer {
  padding: 14px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.filter-apply-btn {
  width: 100%;
  padding: 14px;
  border-radius: .75rem;
  font-size: .92rem;
  font-weight: 700;
  background: var(--grad);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: opacity .15s;
}
.filter-apply-btn:hover { opacity: .9; }
.filter-cancel-btn {
  width: 100%;
  padding: 13px;
  border-radius: .75rem;
  font-size: .88rem;
  font-weight: 500;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  color: var(--muted2);
  cursor: pointer;
  transition: all .15s;
}
.filter-cancel-btn:hover { color: var(--fg); }

/* ── MODAL BOAS-VINDAS / CUPOM ── */
.welcome-coupon-box {
  text-align: center;
  max-width: 320px;
}
.wc-icon {
  font-size: 2.2rem;
  margin-bottom: 10px;
}
.wc-title {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--fg);
  margin-bottom: 8px;
}
.wc-sub {
  font-size: .8rem;
  color: var(--muted2);
  line-height: 1.6;
  margin-bottom: 18px;
}
.wc-discounts {
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: .75rem;
  padding: 12px 14px;
  margin-bottom: 18px;
}
.wc-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.wc-plan {
  font-size: .82rem;
  font-weight: 600;
  color: var(--fg);
  flex: 1;
  text-align: left;
}
.wc-disc {
  font-size: .72rem;
  font-weight: 700;
  color: #4ade80;
  background: rgba(74,222,128,.1);
  border: 1px solid rgba(74,222,128,.2);
  border-radius: 99px;
  padding: 2px 8px;
}
.wc-price {
  font-size: .88rem;
  font-weight: 700;
  color: var(--fg);
  text-align: right;
}
.wc-orig {
  font-size: .68rem;
  font-weight: 400;
  color: var(--muted);
  margin-left: 2px;
}
.wc-btn {
  width: 100%;
  padding: 12px;
  border-radius: var(--r);
  font-size: .88rem;
  font-weight: 700;
  background: var(--grad);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: opacity .15s;
}
.wc-btn:hover { opacity: .9; }

/* ── FADE-IN AO ENTRAR NA VIEWPORT ── */
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(16px); }
  to   { opacity:1; transform:translateY(0); }
}
.scroll-fade {
  opacity: 0;
  transition: opacity .5s ease, transform .5s ease;
  transform: translateY(14px);
}
.scroll-fade.in-view {
  opacity: 1;
  transform: translateY(0);
}
/* respeita delay individual via style="--fd:Xs" */
.scroll-fade { transition-delay: var(--fd, 0s); }
