/* ═══════════════════════════════════════════════════
   CMOVE.AI — Layout Global
   Reset · Portal wrap · Sidebar · Main · Topbar
   PWA Mobile-First — Fixes 07/04/2026
   ═══════════════════════════════════════════════════ */

/* ─── Reset universal ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html,body{width:100%;max-width:100%;overflow-x:hidden;}
html,body{background:var(--bg);color:var(--white);font-family:var(--font);min-height:100vh;}
body{overflow-x:hidden;}

/* ─── Full-width content (Padrão de Ouro) ─── */
#content,#content>*{max-width:100% !important;}
#content>.aprov-layout,#content>.dash-layout{width:100% !important;max-width:100% !important;margin:0 !important;padding:0 !important;}

/* ═══ PORTAL WRAP (Sidebar + Main) ═══ */
/* FIX 1: Sempre visível, sem display:none */
.portal-wrap{
  display:flex;
  flex-direction:row;
  width:100%;
  max-width:100%;
  min-height:100vh;
  background:var(--bg);
}
.portal-wrap.active{
  display:flex;
  flex-direction:row;
  width:100%;
  max-width:100%;
  min-height:100vh;
}

/* ═══ SIDEBAR ═══ */
.sidebar{
  background:var(--bg2);
  border-right:0.5px solid var(--bord);
  display:flex;flex-direction:column;
  height:100vh;position:sticky;top:0;
  width:220px;min-width:220px;max-width:220px;flex-shrink:0;
}
.sb-logo{padding:0 20px;height:60px;display:flex;align-items:center;border-bottom:1px solid var(--bord);flex-shrink:0;}
.logo-mark{font-size:17px;font-weight:900;color:var(--green);letter-spacing:1px;}
.sb-user{padding:14px 20px;border-bottom:0.5px solid var(--bord);display:flex;align-items:center;gap:10px;}
.sb-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;color:#000;font-size:11px;font-weight:700;flex-shrink:0;}
.sb-user-name{font-size:12px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;}
.sb-nav{flex:1;overflow-y:auto;padding:12px 0;}
.nav-sec{font-size:9px;font-weight:700;color:var(--gray3);letter-spacing:2px;text-transform:uppercase;padding:14px 20px 4px;}
.ni{display:flex;align-items:center;gap:10px;padding:9px 18px;cursor:pointer;color:var(--gray2);font-size:12px;font-weight:500;border-left:2px solid transparent;transition:all 0.15s;user-select:none;}
.ni svg{flex-shrink:0;}
.ni:hover{color:var(--white);background:rgba(255,255,255,0.03);}
.ni.on{color:var(--green);background:var(--green-dim);border-left-color:var(--green);}
.ni-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:16px;text-align:center;}

/* ─── Main area ─── */
.main{overflow-y:auto;overflow-x:hidden;min-height:100vh;background:var(--bg);flex:1 1 auto;min-width:0;max-width:100%;box-sizing:border-box;}
.topbar{height:72px;border-bottom:none;padding:0 40px;display:flex;align-items:center;justify-content:space-between;background:var(--bg);position:sticky;top:0;z-index:10;}
.topbar-title{font-size:18px;font-weight:700;color:var(--white);letter-spacing:-0.3px;}
.content{padding:20px 40px 48px !important;width:100% !important;max-width:100% !important;box-sizing:border-box !important;margin:0 !important;}

/* ═══ HAMBURGER BUTTON (FIX 6) ═══ */
.hamburger{
  background:transparent;
  border:none;
  color:var(--white);
  cursor:pointer;
  padding:8px;
  display:none;
  align-items:center;
  justify-content:center;
  margin-right:12px;
  transition:all 0.2s ease;
  flex-shrink:0;
}
.hamburger:hover{color:var(--green);}
.hamburger svg{width:24px;height:24px;stroke-width:2;}

/* ═══ SIDEBAR BACKDROP (FIX 2) ═══ */
.sidebar-backdrop{
  display:none;
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,0.6);
  z-index:998;
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}
.sidebar-backdrop.active{display:block;}

/* ═══ AUTH / LOGIN SCREEN — Split Layout ═══ */
#login-screen{position:fixed;inset:0;z-index:9999;display:flex;background:var(--bg);}
#login-screen.hidden{display:none;}
.login-left{flex:1.1;background:var(--bg2);border-right:1px solid var(--bord2);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;position:relative;overflow:hidden;}
.login-left-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(0,230,118,0.06) 0%,transparent 70%);}
.login-left-content{position:relative;z-index:1;max-width:480px;width:100%;}
.login-brand{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:48px;text-align:center;padding-bottom:28px;border-bottom:1px solid var(--bord2);}
.login-brand-logo{font-size:32px;font-weight:900;color:var(--white);letter-spacing:-1px;}
.login-brand-logo span{color:var(--green);}
.login-tagline{font-size:11px;color:var(--gray2);font-weight:600;letter-spacing:1.8px;text-transform:uppercase;}
.login-headline{font-size:36px;font-weight:900;color:var(--white);line-height:1.15;margin-bottom:16px;letter-spacing:-0.5px;}
.login-headline span{color:var(--green);}
.login-sub{font-size:14px;color:var(--gray2);line-height:1.7;margin-bottom:40px;}
.login-features{display:flex;flex-direction:column;gap:14px;}
.login-feat{display:flex;align-items:flex-start;gap:12px;}
.login-feat-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;margin-top:7px;}
.login-feat-txt{font-size:13px;color:var(--gray1);line-height:1.5;}
.login-feat-txt strong{color:var(--white);font-weight:600;}
.login-right{width:500px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 48px;}
.login-form-wrap{width:100%;max-width:380px;}
.login-form-title{font-size:24px;font-weight:900;color:var(--white);margin-bottom:6px;letter-spacing:-0.3px;}
.login-form-sub{font-size:13px;color:var(--gray2);margin-bottom:36px;}
.login-field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px;}
.login-label{font-size:11px;font-weight:700;color:var(--gray2);text-transform:uppercase;letter-spacing:1px;}
.login-input{background:var(--bg3);border:1px solid var(--bord2);border-radius:8px;padding:13px 16px;font-size:14px;color:var(--white);font-family:var(--font);outline:none;transition:border-color 0.15s,box-shadow 0.15s;width:100%;}
.login-input::placeholder{color:var(--gray3);}
.login-input:focus{border-color:var(--green-border);box-shadow:0 0 0 3px rgba(0,230,118,0.08);}
.login-btn{width:100%;padding:14px;background:var(--green);border:none;border-radius:8px;font-size:14px;font-weight:800;color:#000;font-family:var(--font);cursor:pointer;transition:opacity 0.15s,transform 0.1s;margin-top:8px;letter-spacing:0.3px;}
.login-btn:hover:not(:disabled){opacity:0.9;}
.login-btn:active{transform:scale(0.98);}
.login-btn:disabled{opacity:0.5;cursor:not-allowed;}
.login-footer{margin-top:32px;text-align:center;font-size:12px;color:var(--gray3);}
.login-footer button{background:none;border:none;color:var(--green);cursor:pointer;font-weight:600;font-family:var(--font);font-size:12px;padding:0;}
.login-footer button:hover{text-decoration:underline;}
.login-error{display:none;background:rgba(255,82,82,0.08);border:1px solid rgba(255,82,82,0.2);border-radius:7px;padding:10px 14px;font-size:12px;color:#ff5252;margin-bottom:16px;}
.login-error.show{display:block;}
.login-success{display:none;background:var(--green-dim);border:1px solid var(--green-border);border-radius:7px;padding:10px 14px;font-size:12px;color:var(--green);margin-bottom:16px;}
.login-success.show{display:block;}

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px){
  .login-left{display:none;}
  .login-right{width:100%;padding:40px 32px;}
}

/* ═══ MOBILE — FIX 2, 3, 4 ═══ */
@media(max-width:768px){
  .portal-wrap,.portal-wrap.active{flex-direction:column;}

  /* FIX 2: Sidebar drawer */
  .sidebar{
    position:fixed;
    left:0;top:0;
    width:260px;min-width:260px;max-width:260px;
    height:100vh;
    z-index:1000;
    transform:translateX(-100%);
    transition:transform 0.3s ease;
    padding-top:env(safe-area-inset-top,0);
  }
  .sidebar.mob-open{
    transform:translateX(0);
  }

  /* FIX 3: Main responsivo */
  .main{
    min-height:100vh;
    width:100%;
  }

  /* FIX 4: Topbar menor */
  .topbar{
    padding:0 16px;
    height:56px;
    padding-top:env(safe-area-inset-top,0);
  }
  .topbar-title{font-size:16px;}

  /* Content padding mobile */
  .content{
    padding:16px !important;
  }

  /* Hamburger visível */
  .hamburger{display:flex;}
}

@media(max-width:480px){
  .login-right{padding:32px 20px;}
  .login-form-title{font-size:20px;}
  .content{padding:12px !important;}
}
