/* =====================================================================
   ESTILO DO APP — Tema "Azul Oceano" (inspirado em Booking / Wanderlog)
   Mobile-first · menu lateral (gaveta no celular, fixo no desktop)
   ===================================================================== */
:root{
  --bg:#F4F7FB; --card:#FFFFFF; --ink:#13283D; --muted:#64748B;
  --primary:#0A3D62; --primary-2:#0E4D7B; --accent:#2E86DE; --accent-soft:#E8F1FC;
  --ok:#16A085; --ok-soft:#E4F5F1; --warn:#E1A300; --warn-soft:#FBF1D6; --danger:#E05B49;
  --line:#E6EBF1;
  --shadow:0 1px 2px rgba(16,40,64,.04),0 10px 30px rgba(16,40,64,.06);
  --shadow-lg:0 20px 50px rgba(16,40,64,.16);
  --radius:18px; --sidebar-w:264px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg); color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  line-height:1.55; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand{font-family:'Plus Jakarta Sans','Inter',sans-serif}
a{color:var(--accent)}
.hidden{display:none !important}

/* Barras de rolagem temáticas (desktop) — discretas e no padrão do app */
html{scrollbar-width:thin;scrollbar-color:#C6D2DE transparent}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#C6D2DE;border-radius:8px;border:2px solid var(--bg);background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:#9DB0C2;background-clip:padding-box}

/* ---------------- LOGIN ---------------- */
.login{
  position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(circle at 20% 10%,#15507e 0%,transparent 55%),
             radial-gradient(circle at 85% 90%,#2E86DE 0%,transparent 50%),
             linear-gradient(160deg,#0A3D62 0%,#0c2a40 100%);
}
.login-card{
  width:100%;max-width:370px;background:var(--card);border-radius:24px;padding:36px 28px;
  box-shadow:var(--shadow-lg);text-align:center;animation:rise .5s ease;
}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.login-card .emoji{font-size:2.6rem}
.login-card h1{font-weight:700;font-size:1.55rem;margin:8px 0 2px;color:var(--primary)}
.login-card .who{color:var(--muted);font-size:.95rem;margin-bottom:24px}
.login input{
  width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:13px;
  font-size:1rem;font-family:inherit;background:#F8FAFC;color:var(--ink);outline:none;transition:border-color .15s;
}
.login input:focus{border-color:var(--accent);background:#fff}
.login button{
  width:100%;margin-top:12px;padding:14px;border:none;border-radius:13px;
  background:var(--accent);color:#fff;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;transition:filter .15s;
}
.login button:active{filter:brightness(.93)}
.login .err{color:var(--danger);font-size:.85rem;margin-top:12px;min-height:1.1em}
.login .hint{color:var(--muted);font-size:.74rem;margin-top:18px}
.login .remember{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:14px;font-size:.82rem;color:var(--muted);cursor:pointer}
.login .remember input{width:auto}

/* ---------------- LAYOUT ---------------- */
.app{display:flex;min-height:100%}
.sidebar{
  width:var(--sidebar-w);background:linear-gradient(180deg,var(--primary) 0%,#082B45 100%);
  color:#E8EEF5;display:flex;flex-direction:column;flex-shrink:0;
  position:fixed;inset:0 auto 0 0;z-index:40;transform:translateX(-100%);transition:transform .25s ease;
}
.sidebar.open{transform:none}
.sidebar-head{padding:24px 22px 18px;border-bottom:1px solid rgba(255,255,255,.10)}
.sidebar-head .kicker{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:#7FB3E8;font-weight:700}
.sidebar-head h1{font-weight:700;font-size:1.3rem;margin-top:5px;color:#fff}
.sidebar-head .who{font-size:.78rem;color:rgba(232,238,245,.6);margin-top:3px}
.sidebar-nav{flex:1;overflow-y:auto;padding:12px 12px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.22) transparent}
.sidebar-nav::-webkit-scrollbar{width:8px}
.sidebar-nav::-webkit-scrollbar-track{background:transparent}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
.sidebar-nav::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.30);background-clip:padding-box}
.sidebar-nav a{
  display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;
  color:rgba(232,238,245,.82);text-decoration:none;font-size:.92rem;font-weight:500;margin-bottom:2px;transition:background .15s,color .15s;
}
.sidebar-nav a .ic{font-size:1.05rem;width:22px;text-align:center}
.sidebar-nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.sidebar-nav a.active{background:var(--accent);color:#fff;font-weight:600;box-shadow:0 6px 16px rgba(46,134,222,.4)}
.sidebar-foot{padding:14px 16px;border-top:1px solid rgba(255,255,255,.10)}
.sidebar-foot button{
  width:100%;padding:10px;border:1px solid rgba(255,255,255,.18);border-radius:11px;
  background:transparent;color:rgba(232,238,245,.85);font-family:inherit;font-size:.85rem;cursor:pointer;transition:background .15s;
}
.sidebar-foot button:hover{background:rgba(255,255,255,.08);color:#fff}

.overlay{position:fixed;inset:0;background:rgba(8,24,40,.45);z-index:35;opacity:0;pointer-events:none;transition:opacity .25s}
.overlay.show{opacity:1;pointer-events:auto}

/* INFOBAR — barra fixa no topo (título + relógios + fundo + cotações)
   Fundo SÓLIDO de propósito: backdrop-filter em elemento fixed some/pisca
   ao rolar no mobile (bug conhecido). Sólido = sempre fixa e estável. */
.infobar{
  position:fixed;top:0;left:0;right:0;z-index:30;
  background:var(--card);border-bottom:1px solid var(--line);
  box-shadow:0 2px 10px rgba(16,40,64,.06);
  font-variant-numeric:tabular-nums;color:var(--ink);
  /* força camada própria na GPU → evita o fixed sumir/piscar ao rolar no mobile */
  transform:translateZ(0);-webkit-transform:translateZ(0);
  will-change:transform;-webkit-backface-visibility:hidden;backface-visibility:hidden;
}
.ib-top{display:flex;align-items:center;gap:10px;padding:8px 12px}
.infobar .burger{
  width:38px;height:38px;border:1px solid var(--line);border-radius:11px;background:var(--card);
  display:flex;align-items:center;justify-content:center;font-size:1.15rem;cursor:pointer;color:var(--primary);flex-shrink:0;
}
.ib-title{font-weight:700;font-size:.98rem;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ib-fund{white-space:nowrap;margin-left:auto;font-size:.82rem;color:var(--muted);font-weight:600}
.ib-fund b{color:var(--ok);font-weight:800;font-size:1.04em}
.ib-fund small{color:var(--muted);font-weight:600;font-size:.9em;opacity:.9}
.ib-info{display:flex;align-items:center;gap:4px 14px;flex-wrap:wrap;padding:0 12px 8px;font-size:.74rem}
.clocks{display:flex;align-items:center;gap:3px 10px;flex-wrap:wrap;color:var(--muted)}
.clocks .date{font-weight:700;color:var(--primary);text-transform:capitalize}
.clocks .ck b{color:var(--ink);font-weight:700;margin-left:2px}
.ib-fx{display:flex;gap:5px 12px;flex-wrap:wrap;margin-left:auto}
.ib-fx .fx{white-space:nowrap;color:var(--muted)}
.ib-fx .fx b{color:var(--ink);font-weight:700}
.ib-fx .up{color:var(--ok);font-size:.72em}
.ib-fx .down{color:var(--danger);font-size:.72em}
.infobar .muted{color:var(--muted);opacity:.85}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{max-width:860px;width:100%;margin:0 auto;padding:20px 16px 80px}

/* ---------------- COMPONENTES ---------------- */
.page-head{margin-bottom:8px}
.page-head .kicker{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:700}
.page-head h2{font-weight:700;font-size:1.7rem;letter-spacing:-.02em;line-height:1.1;margin-top:4px;color:var(--ink)}

section.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-top:16px;box-shadow:var(--shadow)}
section.card.accent{border-top:3px solid var(--accent)}
section.card h3.title{font-weight:700;font-size:1.12rem;display:flex;align-items:center;gap:9px;margin-bottom:14px;color:var(--ink)}
h4.sub{font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);font-weight:700;margin:18px 0 8px}
h4.sub:first-child{margin-top:0}
.prose p{margin:7px 0;font-size:.95rem;color:#33475B}
.prose strong{font-weight:600;color:var(--ink)}

/* HERO countdown */
.hero{
  margin-top:4px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 130%);
  color:#fff;border-radius:22px;padding:26px 24px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.hero::after{content:"✈";position:absolute;right:-6px;top:-14px;font-size:7rem;opacity:.10;transform:rotate(18deg)}
.hero .lbl-top{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;opacity:.85;font-weight:700}
.hero .big{font-weight:800;font-size:3rem;line-height:1;margin-top:6px;font-family:'Plus Jakarta Sans',sans-serif}
.hero .lbl{font-size:.92rem;opacity:.92;margin-top:4px}
.hero .meta-line{margin-top:14px;font-size:.82rem;opacity:.9;display:flex;flex-wrap:wrap;gap:6px 16px}

/* KPI cards */
.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:15px 16px;box-shadow:var(--shadow)}
.kpi .ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;background:var(--accent-soft);margin-bottom:9px}
.kpi.green .ic{background:var(--ok-soft)}
.kpi.amber .ic{background:var(--warn-soft)}
.kpi .v{font-weight:800;font-size:1.3rem;letter-spacing:-.02em;color:var(--ink);font-family:'Plus Jakarta Sans',sans-serif}
.kpi .l{font-size:.72rem;color:var(--muted);font-weight:600;margin-top:2px}
.kpi .s{font-size:.7rem;color:var(--muted);margin-top:2px}

/* progress bar */
.progress{height:10px;border-radius:99px;background:#EAEEF3;overflow:hidden;display:flex;margin:10px 0 8px}
.progress span{display:block;height:100%}
.progress .done{background:var(--ok)}
.progress .prog{background:var(--warn)}
.legend-row{display:flex;flex-wrap:wrap;gap:14px;font-size:.8rem;color:var(--muted)}
.legend-row b{color:var(--ink)}
.legend-row i{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:middle}

/* Facts grid */
.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.fact{background:#F8FAFC;border:1px solid var(--line);border-radius:13px;padding:12px 14px}
.fact .l{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
.fact .v{font-weight:700;font-size:.92rem;margin-top:3px;color:var(--ink)}

/* Drive button */
.drive-btn{
  display:flex;align-items:center;gap:14px;width:100%;text-decoration:none;
  background:linear-gradient(135deg,var(--accent) 0%,var(--primary) 130%);color:#fff;
  border-radius:16px;padding:16px 18px;box-shadow:var(--shadow);transition:filter .15s,transform .1s;
}
.drive-btn:active{transform:scale(.99);filter:brightness(.96)}
.drive-btn .dic{font-size:1.5rem;width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.drive-btn .dt{font-weight:700;font-size:1rem}
.drive-btn .ds{font-size:.8rem;opacity:.9;margin-top:1px}
.drive-btn .arr{margin-left:auto;font-size:1.2rem;opacity:.9}

/* Checklist */
ul.check{list-style:none}
ul.check li{display:flex;gap:11px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--line);font-size:.94rem}
ul.check li:last-child{border-bottom:none}
.box{flex-shrink:0;width:20px;height:20px;border-radius:7px;border:1.8px solid #C6D2DE;margin-top:1px;display:flex;align-items:center;justify-content:center;font-size:.72rem;color:#fff;font-weight:700}
li.done .box{background:var(--ok);border-color:var(--ok)}
li.done .box::after{content:"✓"}
li.done .txt{color:var(--muted)}
li.done .txt strong{text-decoration:line-through;text-decoration-color:rgba(100,116,139,.5)}
li.prog .box{background:var(--warn);border-color:var(--warn)}
li.prog .box::after{content:"◐";font-size:.8rem}
.txt strong{font-weight:600;color:var(--ink)}
.txt .s{display:block;color:var(--muted);font-size:.86em;margin-top:1px}
.num{flex-shrink:0;width:23px;height:23px;border-radius:50%;background:var(--accent);color:#fff;font-size:.76rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}
li.done .num{background:var(--ok)}
li.prog .num{background:var(--warn)}

/* Pills */
.pill{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.03em;padding:3px 10px;border-radius:20px;background:var(--accent-soft);color:var(--accent);vertical-align:middle}
.pill.ok{background:var(--ok-soft);color:var(--ok)}
.pill.warn{background:var(--warn-soft);color:#9a7400}

/* Notes */
.note{background:var(--ok-soft);border:1px solid rgba(22,160,133,.22);border-radius:12px;padding:12px 14px;font-size:.88rem;margin-top:12px;color:#1f4f47}
.note.warn{background:var(--warn-soft);border-color:rgba(225,163,0,.28);color:#6b5200}
.note.danger{background:#FBE9E6;border-color:rgba(224,91,73,.28);color:#7a2b20}

/* Tables */
.table-wrap{overflow-x:auto;margin:8px 0;border:1px solid var(--line);border-radius:12px}
table{width:100%;border-collapse:collapse;font-size:.9rem;min-width:380px}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
tr:last-child td{border-bottom:none}
th{font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;white-space:nowrap;background:#F8FAFC}
td:first-child{font-weight:600;color:var(--ink)}
tr.total td{font-weight:700;background:var(--accent-soft);color:var(--primary)}

/* Charts */
.chart-box{margin:12px 0 4px}
.chart-flex{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.chart-flex .chart-c{flex:1 1 200px;min-width:180px;max-width:280px}
.chart-legend{flex:1 1 180px;font-size:.85rem}
.chart-legend .row{display:flex;align-items:center;gap:9px;padding:5px 0}
.chart-legend .row i{width:11px;height:11px;border-radius:3px;flex-shrink:0}
.chart-legend .row .lv{margin-left:auto;font-weight:700;color:var(--ink)}
canvas{max-width:100%}

/* Tendência / variação (verde sobe, vermelho desce) */
.up{color:var(--ok)}
.down{color:var(--danger)}

/* Câmbio */
.period{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.period button{border:1px solid var(--line);background:var(--card);color:var(--muted);border-radius:999px;padding:7px 15px;font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}
.period button.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.fx-now{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:1.7rem;color:var(--ink);display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:2px 0 4px}
.fx-now small{font-size:.8rem;font-weight:700}
.fx-stats{font-size:.84rem;color:var(--muted);margin-bottom:6px}
.fx-stats b{color:var(--ink)}
.trend{font-size:.7rem;font-weight:700;padding:3px 11px;border-radius:999px;margin-left:auto;white-space:nowrap}
.trend.up{background:var(--ok-soft);color:var(--ok)}
.trend.down{background:#FBE9E6;color:var(--danger)}
.trend.flat{background:#EEF2F6;color:var(--muted)}

/* Inglês — busca + frases */
.search{display:flex;gap:8px;margin:8px 0 4px}
/* font-size 16px: evita o zoom automático do iOS ao focar o campo */
.search input{flex:1;min-width:0;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:16px;background:#F8FAFC;color:var(--ink);outline:none;transition:border-color .15s,background .15s}
.search input:focus{border-color:var(--accent);background:#fff}
.search .clear{border:1px solid var(--line);background:var(--card);border-radius:12px;padding:0 16px;cursor:pointer;color:var(--muted);font-family:inherit;font-weight:700;font-size:.85rem;flex-shrink:0}
.search .clear:hover{background:#F1F5F9;color:var(--ink)}
/* chips de atalho por categoria */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 2px}
.chip{border:1px solid var(--line);background:var(--card);color:var(--primary);border-radius:999px;padding:7px 13px;font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.chip:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.cat-block{margin-top:4px;scroll-margin-top:calc(var(--infobar-h, 72px) + 14px)}
.phrase{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.cat-block .phrase:last-child{border-bottom:none}
.phrase .tx{flex:1;min-width:0}
.phrase .en{font-weight:700;color:var(--ink);font-size:.97rem}
.phrase .pt{color:var(--muted);font-size:.85rem;margin-top:1px}
.phrase .say{flex-shrink:0;width:42px;height:42px;border-radius:12px;border:1px solid var(--accent-soft);background:var(--accent-soft);color:var(--accent);font-size:1.15rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,background .15s}
.phrase .say:hover{background:#d7e8fb}
.phrase .say:active{transform:scale(.92)}
.no-result{color:var(--muted);font-style:italic;text-align:center;padding:22px}

/* valor aproximado em R$ ao lado/abaixo de valores em € (discreto) */
.brl-approx{display:block;color:var(--muted);font-size:.8em;font-weight:600;margin-top:1px;white-space:nowrap}
.muted-note{color:var(--muted);font-size:.84rem;margin-top:8px}

/* botão flutuante "voltar ao topo" (discreto, aparece ao rolar) */
#to-top{position:fixed;right:16px;bottom:18px;z-index:25;width:44px;height:44px;border-radius:50%;border:none;
  background:var(--primary);color:#fff;font-size:1.25rem;line-height:1;cursor:pointer;
  box-shadow:0 6px 18px rgba(16,40,64,.28);opacity:0;pointer-events:none;transform:translateY(8px);
  transition:opacity .2s,transform .2s}
#to-top.show{opacity:.92;pointer-events:auto;transform:none}
#to-top:hover{opacity:1}

.foot{text-align:center;color:var(--muted);font-size:.76rem;margin-top:30px}

/* ---------------- DESKTOP ---------------- */
@media (min-width:900px){
  .sidebar{transform:none}
  .infobar{left:var(--sidebar-w)}
  .infobar .burger{display:none}
  .main{margin-left:var(--sidebar-w)}
  .overlay{display:none}
  .content{padding:34px 30px 80px}
  .kpis{grid-template-columns:repeat(4,1fr)}
  .facts{grid-template-columns:repeat(4,1fr)}
  .page-head h2{font-size:2.1rem}
}
