:root{
  --blue:#1b4dd1;
  --blue-dark:#1741b0;
  --bg:#f0f1f3;
  --card:#ffffff;
  --txt:#1c2024;
  --txt-soft:#5b626b;
  --line:#e3e5e8;
  --navy1:#0a2342;
  --navy2:#0e2c52;
  --green:#1f8b3a;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:#c8cbd0;
  color:var(--txt);
  display:flex;justify-content:center;
  min-height:100vh;
}
/* phone frame on desktop, full on mobile */
.app{
  width:100%;max-width:430px;background:var(--bg);
  min-height:100vh;position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
@media(min-width:480px){
  body{padding:24px 0;align-items:flex-start;}
  .app{min-height:880px;height:880px;border-radius:38px;box-shadow:0 30px 70px rgba(0,0,0,.35);}
}

.screen{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.screen::-webkit-scrollbar{display:none;}

/* ===== header ===== */
.header{background:var(--blue);color:#fff;padding:14px 20px 22px;}
.header .row{display:flex;align-items:center;justify-content:space-between;}
.header h1{font-size:22px;margin:0;font-weight:800;letter-spacing:.2px;}
.header .sub{font-size:16px;color:#dfe6fb;margin-top:2px;font-weight:400;}
.header-actions{display:flex;align-items:center;gap:16px;}
.bell{position:relative;width:26px;height:26px;}
.bell:after{content:"";position:absolute;top:0;right:1px;width:8px;height:8px;background:#ff3b30;border-radius:50%;border:1.5px solid var(--blue);}
.avatar{
  width:54px;height:54px;border-radius:50%;background:#111 center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;flex:0 0 auto;
}

/* ===== content ===== */
.content{padding:20px 18px 30px;}
.sec-title{font-size:22px;font-weight:800;margin:6px 2px 14px;}
.sec-title.sm{font-size:20px;}

.card{background:var(--card);border-radius:14px;border:1px solid var(--line);}
.shadow{box-shadow:0 1px 3px rgba(0,0,0,.05);}

/* disciplinas carrossel */
.hscroll{display:flex;gap:14px;overflow-x:auto;padding:2px 2px 6px;scroll-snap-type:x mandatory;}
.hscroll::-webkit-scrollbar{display:none;}
.disc-card{flex:0 0 78%;scroll-snap-align:start;padding:20px 18px 18px;border-radius:14px;}
.disc-card h3{margin:0 0 26px;font-size:20px;font-weight:600;}
.disc-pct{text-align:right;font-size:24px;font-weight:800;margin-bottom:6px;}
.bar{height:4px;background:#e3e5e8;border-radius:3px;overflow:hidden;}
.bar span{display:block;height:100%;background:#111;border-radius:3px;}

.divider{height:1px;background:#dcdee2;margin:22px 4px;}

.renov{display:flex;align-items:center;justify-content:space-between;padding:20px 18px;border-radius:14px;margin-bottom:10px;}
.renov .l{display:flex;align-items:center;gap:12px;}
.renov h3{margin:0;font-size:21px;font-weight:800;}
.badge{background:#dfe1e5;color:#3a3f46;font-size:14px;font-weight:600;padding:6px 14px;border-radius:20px;}
.chev{font-size:20px;color:#222;}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.tile{padding:18px 16px;border-radius:14px;min-height:128px;display:flex;flex-direction:column;justify-content:space-between;position:relative;}
.tile .ic{height:30px;color:#15181c;}
.tile .lbl{font-size:18px;color:#2b2f35;line-height:1.25;}
.tile .tag-new{position:absolute;top:14px;right:14px;background:#3a3f46;color:#fff;font-size:13px;font-weight:600;padding:5px 12px;border-radius:16px;}

.expand{width:100%;border:1.6px solid var(--blue);background:#fff;color:var(--blue);font-size:18px;font-weight:700;
  padding:16px;border-radius:12px;display:flex;align-items:center;justify-content:center;gap:8px;margin:6px 0 4px;cursor:pointer;}

/* benefits banner */
.benefit{border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#fff;}
.benefit .top{background:linear-gradient(115deg,#1b4dd1,#3f74e6 70%,#7aa2f0);padding:22px 20px;color:#fff;position:relative;min-height:150px;}
.benefit .logo-mini{display:flex;align-items:center;gap:8px;font-weight:800;font-size:20px;margin-bottom:14px;}
.benefit .logo-mini img{height:26px;}
.benefit .top p{margin:0;font-size:22px;font-weight:800;line-height:1.2;max-width:60%;}
.benefit .deco{position:absolute;right:-10px;bottom:-10px;width:150px;height:150px;border-radius:50%;background:rgba(255,255,255,.12);}
.benefit .deco2{position:absolute;right:40px;top:18px;width:70px;height:70px;border-radius:50%;background:rgba(255,255,255,.10);}
.benefit .body{padding:18px 18px 20px;}
.benefit .body p{margin:0 0 16px;font-size:17px;color:#3a3f46;line-height:1.4;}
.btn-primary{width:100%;background:var(--blue);color:#fff;border:none;font-size:18px;font-weight:700;padding:16px;border-radius:10px;cursor:pointer;}

/* ===== financeiro ===== */
.fin-header{background:var(--blue);color:#fff;padding:16px 20px 70px;}
.fin-header .top{display:flex;align-items:flex-start;justify-content:space-between;}
.fin-header .hi{font-size:16px;color:#dfe6fb;}
.fin-header .course{font-size:24px;font-weight:800;margin-top:2px;}
.fin-header h2{font-size:21px;font-weight:800;margin:20px 0 0;}
.fin-grid{padding:0 18px;margin-top:-46px;}

/* ===== perfil ===== */
.perfil-top{background:var(--blue);color:#fff;padding:14px 20px 60px;text-align:center;}
.perfil-top .ttl{font-size:18px;font-weight:600;color:#eaf0ff;}
.perfil-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:14px;font-size:30px;font-weight:800;letter-spacing:.3px;}
.perfil-logo img{height:36px;}
.carteira-wrap{padding:0 16px;margin-top:-44px;}
.carteira{
  background:linear-gradient(150deg,var(--navy1),var(--navy2));
  border:1.5px solid #cdd9ef;border-radius:18px;color:#fff;padding:22px 20px;
  box-shadow:0 10px 24px rgba(10,35,66,.3);
}
.ct-head{display:flex;align-items:center;gap:18px;}
.ct-head .photo{width:84px;height:84px;border-radius:50%;background:#111 center/cover no-repeat;flex:0 0 auto;}
.ct-head .nm{font-size:23px;font-weight:600;line-height:1.15;}
.ct-active{display:inline-block;margin-top:8px;background:var(--green);color:#fff;font-size:14px;font-weight:700;letter-spacing:.5px;padding:5px 14px;border-radius:6px;}
.ct-line{height:1px;background:rgba(255,255,255,.18);margin:20px 0;}
.ct-grid{display:flex;gap:30px;}
.ct-grid.cols .col{flex:1;}
.ct-lbl{font-size:14px;font-weight:700;color:#dbe4f5;}
.ct-val{font-size:19px;margin-top:3px;color:#fff;font-weight:500;}
.ct-block{margin-bottom:16px;}
.ct-foot{display:flex;justify-content:space-between;align-items:flex-end;}
.ct-copy{opacity:.8;font-size:20px;}
.recolher{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--blue);font-weight:700;font-size:18px;padding:22px;cursor:pointer;}
.conta{padding:0 18px 30px;}
.conta h2{font-size:24px;font-weight:800;margin:6px 2px 16px;}
.conquista{display:flex;align-items:center;gap:14px;padding:18px;border:1px solid #cdd9f5;border-radius:12px;background:#fff;margin-bottom:14px;}
.conquista .st{width:34px;height:34px;border-radius:8px;background:#eef2fd;display:flex;align-items:center;justify-content:center;color:var(--blue);}
.conquista span{font-size:18px;font-weight:600;}
.conta-list{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;}
.conta-list a{display:block;padding:18px;font-size:18px;color:var(--txt);text-decoration:none;border-bottom:1px solid var(--line);}
.conta-list a:last-child{border-bottom:none;}
.sair{display:block;text-align:center;color:var(--blue);font-weight:700;font-size:18px;padding:26px;cursor:pointer;text-decoration:none;}
.versao{text-align:center;color:var(--txt-soft);font-size:15px;padding-bottom:24px;}

/* ===== bottom nav ===== */
.tabbar{flex:0 0 auto;background:#fafafa;border-top:1px solid #e6e6e6;display:flex;padding:10px 4px 8px;}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;color:#9aa0a8;font-size:13px;cursor:pointer;background:none;border:none;font-family:inherit;text-decoration:none;}
.tab svg{width:26px;height:26px;}
.tab.active{color:var(--blue);}
.home-ind{height:6px;background:#fafafa;}
.home-ind:after{content:"";display:block;width:140px;height:5px;background:#111;border-radius:3px;margin:6px auto 8px;}

/* ===== login / selection ===== */
.select{flex:1;min-height:0;background:linear-gradient(160deg,#1b4dd1,#0e2c52);
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px;color:#fff;}
.select .logo{display:flex;align-items:center;gap:12px;font-size:34px;font-weight:800;margin-bottom:6px;}
.select .logo img{height:46px;}
.select .hint{color:#cdd9f5;font-size:16px;margin-bottom:34px;}
.pick{display:flex;flex-direction:column;gap:16px;width:100%;max-width:320px;}
.pick a{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.25);
  border-radius:16px;padding:16px;color:#fff;font-family:inherit;cursor:pointer;text-align:left;text-decoration:none;backdrop-filter:blur(4px);}
.pick a:hover{background:rgba(255,255,255,.16);}
.pick .ph{width:60px;height:60px;border-radius:50%;background:#111 center/cover no-repeat;flex:0 0 auto;border:2px solid rgba(255,255,255,.4);}
.pick .nm{font-size:18px;font-weight:700;}
.pick .cs{font-size:14px;color:#cdd9f5;}
