/* ============================================================
   styles.css — Gestor de Viagem Cancún 2026
   Mobile-first, offline, vibe Caribe (turquesa/areia/coral)
   ============================================================ */
:root{
  --teal:#0ea5b7; --teal-d:#0b7e8c; --teal-l:#e6f7f9;
  --sand:#fbf7ef; --sand-d:#f1e8d8;
  --coral:#ff6b5e; --coral-d:#e8483a;
  --amber:#f59e0b; --green:#16a34a; --green-l:#dcfce7;
  --ink:#11272b; --muted:#5b6f73; --line:#e4e9ea;
  --card:#ffffff; --bg:#f4f7f8;
  --shadow:0 1px 3px rgba(11,40,44,.08), 0 6px 20px rgba(11,40,44,.06);
  --r:14px;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0;padding:0;overflow-x:hidden}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:var(--bg);
  padding-bottom:64px; -webkit-text-size-adjust:100%;
}
h1,h2,h3{margin:0 0 .4em}
a{color:var(--teal-d)}
button{font-family:inherit;cursor:pointer}

/* ---------- Topbar ---------- */
.topbar{
  position:sticky;top:0;z-index:40;
  background:linear-gradient(135deg,var(--teal),var(--teal-d));
  color:#fff; box-shadow:var(--shadow);
  padding-top:env(safe-area-inset-top);
}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.brand-emoji{font-size:26px}
.brand-text{display:flex;flex-direction:column;line-height:1.1;min-width:0}
.brand-text strong{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-text small{opacity:.85;font-size:12px}
.countdown{
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);
  border-radius:12px;padding:6px 12px;text-align:center;min-width:62px;backdrop-filter:blur(4px)
}
.cd-num{display:block;font-size:20px;font-weight:800;line-height:1}
.cd-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.5px;opacity:.9}

/* ---------- Tabs ---------- */
.tabs{
  display:flex;gap:4px;overflow-x:auto;padding:0 10px 10px;
  scrollbar-width:none;-ms-overflow-style:none;
}
.tabs::-webkit-scrollbar{display:none}
.tab{
  flex:0 0 auto;background:rgba(255,255,255,.14);color:#fff;border:none;
  padding:8px 13px;border-radius:999px;font-size:13px;font-weight:600;
  white-space:nowrap;opacity:.85;transition:.15s;display:flex;align-items:center;gap:5px
}
.tab:hover{opacity:1}
.tab.active{background:#fff;color:var(--teal-d);opacity:1;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.tab .badge{background:var(--coral);color:#fff;border-radius:999px;font-size:10px;padding:1px 6px;font-weight:700}
.tab.active .badge{background:var(--coral)}

/* ---------- View / layout ---------- */
.view{max-width:920px;margin:0 auto;padding:16px 14px 28px;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.section-head h2{font-size:20px;display:flex;align-items:center;gap:8px}
.section-sub{color:var(--muted);font-size:13px;margin:-6px 0 14px}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:14px;margin-bottom:12px}
.card.pad-lg{padding:18px}
.grid{display:grid;gap:12px}
.grid-2{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.spread{justify-content:space-between}
.muted{color:var(--muted)}
.tiny{font-size:12px}
.right{text-align:right}
.mt{margin-top:10px}.mb{margin-bottom:10px}

/* ---------- Buttons ---------- */
.btn{background:var(--teal);color:#fff;border:none;padding:10px 16px;border-radius:10px;font-weight:700;font-size:14px;transition:.15s}
.btn:hover{background:var(--teal-d)}
.btn.coral{background:var(--coral)} .btn.coral:hover{background:var(--coral-d)}
.btn.sm{padding:7px 12px;font-size:13px}
.btn.block{width:100%}
.ghost{background:transparent;border:1px solid var(--line);color:var(--ink);padding:8px 13px;border-radius:10px;font-weight:600;font-size:13px}
.ghost:hover{background:#f0f4f5}
.ghost.danger{color:var(--coral-d);border-color:#f3c9c5}
.icon-btn{background:transparent;border:none;font-size:18px;color:var(--muted);padding:4px 6px;border-radius:8px}
.icon-btn:hover{background:#eef2f3;color:var(--ink)}
.link-btn{background:none;border:none;color:var(--teal-d);font-weight:600;padding:0;text-decoration:underline}

/* ---------- Forms ---------- */
label.fld{display:block;margin-bottom:12px;font-size:13px;font-weight:600;color:var(--muted)}
label.fld span{display:block;margin-bottom:5px}
input,select,textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;font-size:15px;
  background:#fff;color:var(--ink);font-family:inherit
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-l)}
textarea{resize:vertical;min-height:64px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}
@media(max-width:520px){.form-grid{grid-template-columns:1fr}}

/* ---------- Chips / tags ---------- */
.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--muted)}
.chip.on{background:var(--teal);color:#fff;border-color:var(--teal)}
.cat-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:700;color:#fff}
.pill{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700}
.pill.ok{background:var(--green-l);color:#15803d}
.pill.pend{background:#fff4e5;color:#b45309}
.pill.warn{background:#fde8e8;color:#b91c1c}

/* ---------- Dashboard ---------- */
.hero{background:linear-gradient(135deg,#0ea5b7,#0891b2 55%,#22c1cc);color:#fff;border-radius:18px;padding:20px;margin-bottom:14px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.hero h2{font-size:22px}
.hero .sun{position:absolute;right:-20px;top:-20px;font-size:120px;opacity:.18}
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:10px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px;text-align:center;box-shadow:var(--shadow)}
.stat .n{font-size:22px;font-weight:800;color:var(--teal-d)}
.stat .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}

/* progress bar */
.bar{height:8px;background:#eef2f3;border-radius:999px;overflow:hidden}
.bar>i{display:block;height:100%;background:var(--green);border-radius:999px;transition:width .4s}

/* ---------- Lists / itens ---------- */
.li{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.li:last-child{border-bottom:none}
.li .grow{flex:1;min-width:0}
.check{width:22px;height:22px;border-radius:7px;border:2px solid var(--line);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;background:#fff;font-size:13px;color:#fff}
.check.on{background:var(--green);border-color:var(--green)}
.done{text-decoration:line-through;color:var(--muted)}

/* ---------- Atrações (passeios) ---------- */
.atr-card{display:flex;flex-direction:column;gap:8px;position:relative}
.atr-card .top{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.atr-card h3{font-size:15px;line-height:1.25}
.atr-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.atr-card .desc{font-size:13px;color:var(--muted);line-height:1.45}
.atr-card .dica{font-size:12px;background:var(--teal-l);border-radius:8px;padding:8px 10px;color:var(--teal-d)}
.flag-btn{border:1px solid var(--teal);background:#fff;color:var(--teal-d);border-radius:10px;padding:7px 12px;font-weight:700;font-size:13px;display:flex;align-items:center;gap:6px}
.flag-btn.on{background:var(--coral);border-color:var(--coral);color:#fff}

/* ---------- Roteiro / agenda ---------- */
.day{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);margin-bottom:14px;overflow:hidden}
.day-head{background:var(--sand);padding:11px 14px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line)}
.day-head .d-num{background:var(--teal);color:#fff;width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px}
.day-head .d-date{font-weight:700;font-size:14px}
.day-head .d-week{font-size:12px;color:var(--muted);text-transform:capitalize}
.day-body{padding:6px 14px 12px}
.slot{padding:8px 0;border-bottom:1px dashed var(--line)}
.slot:last-child{border-bottom:none}
.slot-lbl{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px;display:flex;align-items:center;gap:6px}
.ev{display:flex;align-items:flex-start;gap:9px;padding:7px 9px;border-radius:10px;background:#f8fbfb;margin-bottom:6px;border:1px solid var(--line)}
.ev .ic{font-size:18px;flex:0 0 auto}
.ev .grow{flex:1;min-width:0}
.ev .ev-t{font-weight:700;font-size:14px}
.ev .ev-s{font-size:12px;color:var(--muted)}
.ev.auto{background:#fff7ed;border-color:#fed7aa}
.ev.logi{background:var(--teal-l);border-color:#bfe9ee}
.tray{background:#fff;border:1px dashed var(--coral);border-radius:var(--r);padding:12px;margin-bottom:14px}

/* ---------- Cotador / chart ---------- */
.price-now{font-size:26px;font-weight:800;color:var(--ink)}
.delta-up{color:var(--coral-d);font-weight:700}
.delta-down{color:var(--green);font-weight:700}
.chart-wrap{width:100%;overflow:hidden;border-radius:10px;background:#fbfdfd;border:1px solid var(--line);padding:8px}
canvas{display:block;width:100%;height:auto}
.thumb{width:46px;height:46px;border-radius:8px;object-fit:cover;border:1px solid var(--line);cursor:pointer;flex:0 0 auto}
.img-full{max-width:100%;border-radius:10px}

/* ---------- Empty ---------- */
.empty{text-align:center;color:var(--muted);padding:30px 14px}
.empty .em-ic{font-size:42px;opacity:.6}
.empty p{margin:8px 0 14px}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(11,40,44,.5);display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0;backdrop-filter:blur(2px)}
.modal-card{background:#fff;width:100%;max-width:560px;border-radius:18px 18px 0 0;max-height:92vh;overflow:auto;animation:slideup .25s ease}
@media(min-width:560px){.modal-overlay{align-items:center;padding:20px}.modal-card{border-radius:18px}}
@keyframes slideup{from{transform:translateY(30px);opacity:.6}to{transform:none;opacity:1}}
.modal-head{position:sticky;top:0;background:#fff;display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}
.modal-head strong{font-size:17px}
.modal-body{padding:16px 18px 22px}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:78px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:999px;font-size:14px;z-index:200;box-shadow:var(--shadow);animation:fade .2s}

/* ---------- Footbar ---------- */
.footbar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);display:flex;align-items:center;gap:8px;padding:9px 14px;padding-bottom:calc(9px + env(safe-area-inset-bottom));z-index:30}
.foot-note{flex:1;font-size:11px;color:var(--muted);text-align:center}
@media(max-width:420px){.foot-note{display:none}}
