/* ============================================================================
   SIDE CONNECT — hub PWA (cinematic dark + gold)
   ========================================================================== */
:root{
  --void:#0B0D11; --abyss:#0F1217; --surface:#14181F; --surface-2:#1B2029;
  --ivory:#F4F0E8; --stone:#CBC6BC; --stone-soft:#9C988E; --stone-dim:#76736B;
  --line:rgba(255,255,255,.10); --line-soft:rgba(255,255,255,.05);
  --gold:#F7B500; --gold-bright:#FFD24D; --gold-deep:#B88600; --gold-glow:rgba(247,181,0,.40);
  --r-sm:10px; --r-md:16px; --r-lg:22px; --r-pill:999px;
  --ease:cubic-bezier(.16,1,.3,1);
  --nav-h:70px;
  --font-display:"Cormorant Garamond",Georgia,serif;
  --font-ui:"Space Grotesk","Inter",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{min-height:100vh;background:var(--void);color:var(--stone);font-family:var(--font-ui);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--gold);color:#000}
.mono{font-family:var(--font-ui);letter-spacing:.26em;text-transform:uppercase;font-size:.68rem;color:var(--stone-dim)}
.bg-glow{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(60% 45% at 50% -5%,rgba(247,181,0,.10),transparent 60%),radial-gradient(50% 40% at 90% 100%,rgba(247,181,0,.05),transparent 60%)}

/* ---------- TOP NAV ---------- */
.cnav{position:sticky;top:0;z-index:50;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(1.1rem,4vw,2.4rem);background:rgba(8,9,12,.7);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.cnav__logo img{height:30px;width:auto}
.cnav__right{display:flex;align-items:center;gap:1rem}
.menu-pop{position:relative}
.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1a1206;
  display:grid;place-items:center;font-weight:700;font-size:.85rem;cursor:pointer;border:1px solid var(--gold-bright)}
.menu-pop__list{position:absolute;right:0;top:50px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  min-width:230px;padding:.5rem;box-shadow:0 24px 60px -24px rgba(0,0,0,.85);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.2s}
.menu-pop:hover .menu-pop__list,.menu-pop:focus-within .menu-pop__list{opacity:1;visibility:visible;transform:none}
.menu-pop__head{padding:.6rem .7rem}
.menu-pop__head b{display:block;color:var(--ivory);font-size:.95rem}
.menu-pop__head span{color:var(--stone-dim);font-size:.78rem}
.menu-pop__list a{display:block;padding:.7rem .7rem;border-radius:8px;font-size:.9rem;color:var(--stone)}
.menu-pop__list a:hover{background:var(--surface-2);color:var(--ivory)}
.menu-pop__list .sep{height:1px;background:var(--line);margin:.3rem 0}

/* ---------- HUB ---------- */
.hub{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:clamp(2rem,6vw,4rem) clamp(1.1rem,4vw,2.4rem) 4rem}
.hub__hello{margin-bottom:clamp(2rem,5vw,3rem)}
.hub__kicker{color:var(--gold);font-weight:600;letter-spacing:.24em;text-transform:uppercase;font-size:.7rem;margin-bottom:.9rem}
.hub__hello h1{font-family:var(--font-display);font-weight:300;font-size:clamp(2.6rem,8vw,4.6rem);line-height:1;color:var(--ivory)}
.hub__sub{margin-top:.9rem;color:var(--stone-soft);font-size:clamp(1rem,2.2vw,1.2rem);max-width:46ch}
.hub__empty{color:var(--stone-dim);padding:2rem;border:1px dashed var(--line);border-radius:var(--r-md);text-align:center}

.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.1rem}
.app-tile{position:relative;display:flex;align-items:center;gap:1.1rem;padding:1.4rem 1.5rem;border-radius:var(--r-md);
  background:linear-gradient(135deg,var(--surface),var(--abyss));border:1px solid var(--line);overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.app-tile::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}
.app-tile::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 100% at 0% 0%,color-mix(in srgb,var(--accent) 14%,transparent),transparent 60%);opacity:0;transition:opacity .3s}
.app-tile:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--accent) 45%,var(--line));box-shadow:0 24px 50px -28px rgba(0,0,0,.9)}
.app-tile:hover::after{opacity:1}
.app-tile__icon{flex:0 0 auto;width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--accent) 16%,var(--surface-2));border:1px solid color-mix(in srgb,var(--accent) 35%,transparent)}
.app-tile__icon svg{width:26px;height:26px;color:var(--accent)}
.app-tile__body{flex:1;min-width:0}
.app-tile__body b{display:block;color:var(--ivory);font-family:var(--font-display);font-size:1.45rem;font-weight:500;line-height:1.1}
.app-tile__body small{display:block;color:var(--stone-soft);font-size:.85rem;margin-top:.2rem}
.app-tile__go{flex:0 0 auto;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--surface-2);color:var(--stone-soft);transition:.25s}
.app-tile__go svg{width:18px;height:18px}
.app-tile:hover .app-tile__go{background:var(--accent);color:#0B0D11;transform:translateX(2px)}

/* ---------- BUTTONS / FIELDS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;font-family:inherit;font-weight:600;font-size:.95rem;
  padding:.9rem 1.7rem;border-radius:var(--r-pill);cursor:pointer;border:1px solid transparent;transition:.25s var(--ease);width:100%}
.btn svg{width:18px;height:18px}
.btn--gold{background:var(--gold);color:#000}
.btn--gold:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 18px 44px -16px var(--gold-glow)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--stone-dim);margin-bottom:.5rem}
.field input{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:.95rem 1rem;
  color:var(--ivory);font-family:inherit;font-size:1rem;transition:border-color .25s}
.field input:focus{outline:none;border-color:var(--gold)}
.err{background:rgba(220,60,60,.14);border:1px solid rgba(220,60,60,.4);color:#f3b4b4;padding:.7rem 1rem;border-radius:var(--r-sm);font-size:.88rem;margin-bottom:1.1rem}

/* ---------- LOGIN ---------- */
.login-body{display:grid;place-items:center;min-height:100svh;padding:2rem 1.4rem calc(env(safe-area-inset-bottom) + 2rem)}
.clogin{position:relative;z-index:1;width:100%;max-width:400px;text-align:center}
.clogin__logo{height:42px;width:auto;margin:0 auto 2rem}
.clogin__kicker{color:var(--gold);letter-spacing:.4em;text-transform:uppercase;font-size:.7rem;margin-bottom:1rem}
.clogin h1{font-family:var(--font-display);font-weight:300;font-size:2.6rem;color:var(--ivory);line-height:1}
.clogin__sub{color:var(--stone-soft);margin:.7rem 0 2rem}
.clogin form{text-align:left}
.clogin__hint{margin-top:1.6rem;font-size:.8rem;color:var(--stone-dim)}

/* ---------- FOOTER ---------- */
.cftr{position:relative;z-index:1;text-align:center;padding:2rem 1rem calc(env(safe-area-inset-bottom) + 2rem);border-top:1px solid var(--line-soft)}

@media(max-width:560px){
  .apps-grid{grid-template-columns:1fr}
  .app-tile__body b{font-size:1.3rem}
  .clogin h1{font-size:2.2rem}
}

/* fix: itens da grade encolhem (sem overflow horizontal no mobile) */
.app-tile{min-width:0}
.app-tile__body b,.app-tile__body small{overflow-wrap:anywhere}
@media(max-width:560px){ body{overflow-x:hidden} .hub__sub{max-width:100%} }
/* fix definitivo overflow horizontal */
html{overflow-x:hidden;width:100%}
.cnav,.hub,.cftr{max-width:100%}
@media(max-width:560px){ .hub{padding-left:1.1rem;padding-right:1.1rem} .hub__hello,.apps-grid{max-width:100%} }
/* fix raiz: grid tracks não estouram (minmax 0 / min(280px,100%)) */
.apps-grid{grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr))}
@media(max-width:560px){ .apps-grid{grid-template-columns:minmax(0,1fr)} }
.remember{display:flex;align-items:center;gap:.6rem;color:var(--stone-soft);font-size:.85rem;margin:.2rem 0 1.1rem;cursor:pointer;user-select:none}
.remember input{width:18px;height:18px;accent-color:var(--gold);cursor:pointer}

/* ============================ HUB v2 ============================ */
.hub{padding-bottom:calc(82px + env(safe-area-inset-bottom))}
.hero{position:relative;padding:clamp(1.4rem,5vw,2.6rem) 0 clamp(1.2rem,4vw,2rem);overflow:visible}
.hero__txt{position:relative;z-index:2;max-width:64%}
.hero h1{font-family:var(--font-display);font-weight:300;font-size:clamp(2.4rem,9vw,4rem);line-height:1;color:var(--ivory);margin:.35rem 0 .2rem}
.orbit{position:absolute;top:-8px;right:-26px;width:min(44vw,250px);z-index:1;pointer-events:none}
.orbit svg{width:100%;height:auto;overflow:visible}
.oring{fill:none;stroke:rgba(247,181,0,.18);stroke-width:1}
.ospoke{fill:none;stroke:var(--gold);stroke-width:.9;opacity:.32;stroke-linecap:round;filter:drop-shadow(0 0 2px var(--gold-glow))}
.ospoke.dim{opacity:.18}
.odot{fill:var(--gold);filter:drop-shadow(0 0 5px var(--gold-glow))}
.odot.dim{fill:rgba(247,181,0,.5)}
.ocore{fill:rgba(11,13,17,.82);stroke:rgba(247,181,0,.30);stroke-width:1}
.omono__s{fill:none;stroke:var(--ivory);stroke-width:62;stroke-linecap:round;stroke-linejoin:round}
.omono__d{fill:var(--gold)}
.ospin{transform-origin:110px 110px}
.ospin.a{animation:ospin 20s linear infinite}
.ospin.b{animation:ospin 13s linear infinite reverse}
.ospin.c{animation:ospin 28s linear infinite}
@keyframes ospin{to{transform:rotate(360deg)}}

.wgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(290px,100%),1fr));gap:1rem;margin-top:.4rem}
.wcard{position:relative;display:flex;flex-direction:column;gap:.9rem;padding:1.25rem 1.35rem;border-radius:18px;min-width:0;overflow:hidden;
  background:linear-gradient(150deg,color-mix(in srgb,var(--accent) 10%,var(--surface)),var(--abyss));border:1px solid var(--line);
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.wcard::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 85% at 100% 0,color-mix(in srgb,var(--accent) 18%,transparent),transparent 55%);opacity:.7;pointer-events:none}
.wcard:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--accent) 50%,var(--line));box-shadow:0 24px 50px -28px rgba(0,0,0,.9)}
.wcard__head{display:flex;align-items:center;gap:.85rem;position:relative;z-index:1;min-width:0}
.wcard__icon{flex:0 0 auto;width:48px;height:48px;border-radius:13px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 20%,var(--surface-2));border:1px solid color-mix(in srgb,var(--accent) 38%,transparent)}
.wcard__icon svg{width:24px;height:24px;color:var(--accent)}
.wcard__name{flex:1;min-width:0}
.wcard__name b{display:block;font-family:var(--font-display);font-size:1.35rem;color:var(--ivory);line-height:1.05}
.wcard__name small{display:block;color:var(--stone-soft);font-size:.78rem;margin-top:.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wcard__go{flex:0 0 auto;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--surface-2);color:var(--stone-soft);transition:.25s}
.wcard__go svg{width:16px;height:16px}
.wcard:hover .wcard__go{background:var(--accent);color:#0B0D11}
.wcard__stat{position:relative;z-index:1;display:flex;align-items:center;gap:.75rem;min-height:40px;color:var(--stone);font-size:.9rem;padding-top:.85rem;border-top:1px solid var(--line-soft)}
.wcard__stat .big{font-family:var(--font-display);font-size:1.7rem;color:var(--ivory);line-height:1}
.wcard__stat i{color:var(--stone-dim);font-style:normal}
.wcard__stat .ok{color:var(--accent)}
.wcard__stat .muted{color:var(--stone-soft)}
.skel{display:inline-block;height:12px;border-radius:6px;width:96px;background:linear-gradient(90deg,var(--surface-2),var(--surface),var(--surface-2));background-size:200% 100%;animation:sk 1.2s infinite}
.skel.s2{width:54px}
@keyframes sk{to{background-position:-200% 0}}
.ring{position:relative;width:44px;height:44px;flex:0 0 auto}
.ring svg{width:44px;height:44px;transform:rotate(-90deg)}
.ring .rbg{fill:none;stroke:var(--surface-2);stroke-width:3.5}
.ring .rfg{fill:none;stroke:var(--accent);stroke-width:3.5;stroke-linecap:round;transition:stroke-dashoffset 1s var(--ease)}
.ring b{position:absolute;inset:0;display:grid;place-items:center;font-size:.7rem;color:var(--ivory);font-weight:600}
.ringtxt{min-width:0;font-size:.84rem;color:var(--stone-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.quick{margin-top:1.6rem}
.quick__title{display:flex;align-items:center;gap:.4rem;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.9rem}
.quick__row{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;background:var(--abyss);border:1px solid var(--line);border-radius:16px;padding:1.1rem .6rem}
.quick__row a{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;color:var(--stone-soft);font-size:.7rem;line-height:1.2;transition:color .2s}
.quick__row a:hover{color:var(--ivory)}
.qi{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line)}
.qi svg{width:20px;height:20px;color:var(--gold)}

.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;justify-content:space-around;align-items:center;
  background:rgba(8,9,12,.92);backdrop-filter:blur(16px);border-top:1px solid var(--line);padding:.5rem 0 calc(env(safe-area-inset-bottom) + .5rem)}
.tabbar a{display:flex;flex-direction:column;align-items:center;gap:.22rem;color:var(--stone-dim);font-size:.64rem;padding:.35rem 1.3rem;transition:color .2s}
.tabbar a svg{width:22px;height:22px}
.tabbar a.active{color:var(--gold)}

.prof{text-align:center;padding:1.4rem 0 .5rem}
.prof__av{width:82px;height:82px;border-radius:50%;margin:0;background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1a1206;display:inline-grid;place-items:center;font-size:1.7rem;font-weight:700;border:2px solid var(--gold-bright);position:relative;cursor:pointer}
.prof h1{font-family:var(--font-display);font-weight:300;font-size:2.1rem;color:var(--ivory)}
.prof__sub{color:var(--stone-soft);margin-top:.3rem;font-size:.9rem}
.prof__avform{margin:0 0 1rem}
.prof__avin{width:100%;height:100%;border-radius:50%;overflow:hidden;display:grid;place-items:center}
.prof__avin img,.avatar img{width:100%;height:100%;object-fit:cover;display:block}
.avatar{overflow:hidden}
.prof__cam{position:absolute;right:-3px;bottom:-3px;width:32px;height:32px;border-radius:50%;background:var(--gold);color:#0B0D11;display:grid;place-items:center;border:3px solid var(--void);box-shadow:0 4px 12px rgba(0,0,0,.45)}
.prof__cam svg{width:15px;height:15px}
.prof__editbtn{margin-top:.9rem;background:none;border:1px solid var(--line);color:var(--stone);font:inherit;font-size:.85rem;padding:.5rem 1.1rem;border-radius:999px;cursor:pointer;transition:.2s}
.prof__editbtn:hover{border-color:rgba(247,181,0,.5);color:var(--gold-bright)}
.flash{margin:1rem auto 0;max-width:360px;padding:.7rem 1rem;border-radius:12px;font-size:.88rem}
.flash--s{background:rgba(247,181,0,.12);color:var(--gold-bright);border:1px solid rgba(247,181,0,.32)}
.flash--e{background:rgba(255,90,90,.1);color:#ff9a9a;border:1px solid rgba(255,90,90,.32)}
.pcard{background:var(--abyss);border:1px solid var(--line);border-radius:16px;padding:1.3rem 1.4rem;margin-top:1rem}
.pcard h3{font-family:var(--font-display);font-size:1.3rem;color:var(--ivory);margin-bottom:.8rem}
.pmuted{color:var(--stone-soft);font-size:.88rem;margin-bottom:1.1rem;line-height:1.55}
.ptags{display:flex;flex-wrap:wrap;gap:.5rem}
.ptag{font-size:.8rem;padding:.4rem .9rem;border-radius:99px;background:var(--surface);border:1px solid var(--line);color:var(--stone)}
.btn--ghost-out{display:inline-flex;width:auto;background:transparent;border:1px solid var(--line);color:var(--stone);padding:.7rem 1.4rem}
.btn--ghost-out:hover{border-color:#dc6b6b;color:#f0a8a8;transform:none;box-shadow:none}
.page-h{font-family:var(--font-display);font-weight:300;font-size:2rem;color:var(--ivory);margin:.4rem 0 1.3rem}
.feed{display:flex;flex-direction:column}
.feed__item{display:flex;align-items:center;gap:.9rem;padding:.9rem .1rem;border-bottom:1px solid var(--line-soft)}
.feed__dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 8px currentColor}
.feed__item b{color:var(--ivory);font-weight:500;font-size:.92rem;display:block}
.feed__item small{color:var(--stone-dim);font-size:.76rem}

@media(max-width:560px){
  .hero__txt{max-width:68%}
  .orbit{width:42vw;right:-20px;top:-2px}
  .wgrid{grid-template-columns:1fr}
  .quick__row{grid-template-columns:repeat(2,1fr);gap:.8rem 0.5rem}
}
/* ícones 3D (Nano Banana) nos widgets */
.wcard__icon{width:78px;height:78px;border-radius:16px;overflow:hidden;background:#0B0D11;border:1px solid color-mix(in srgb,var(--accent) 28%,var(--line));padding:0;box-shadow:inset 0 0 24px color-mix(in srgb,var(--accent) 14%,transparent)}
.wcard__icon img{width:100%;height:100%;object-fit:contain;display:block}
.wcard__name b{font-size:1.4rem}
@media(max-width:560px){ .wcard__icon{width:66px;height:66px} }
/* paleta SIDE: cards dark neutros, dourado como único acento */
.wcard{background:linear-gradient(155deg,var(--surface),var(--abyss))}
.wcard::after{background:radial-gradient(110% 80% at 100% 0,rgba(247,181,0,.06),transparent 55%);opacity:1}
.wcard:hover{border-color:rgba(247,181,0,.4)}
.wcard__icon{border-color:rgba(247,181,0,.16);box-shadow:inset 0 0 22px rgba(247,181,0,.07)}
