:root{
  --soil:#3d2b1f;--soil-mid:#5c3d2e;--soil-light:#8b6348;
  --crop:#4a7c3f;--crop-bright:#6aaf5c;
  --sky:#1a3a5c;--sky-mid:#1f5280;--sky-light:#3b7bbf;
  --gold:#d4a843;--gold-light:#f0cc6e;
  --warm:#f5ede0;--white:#fdfaf5;
  --danger:#c0392b;--warn:#e67e22;--ok:#27ae60;--info:#2980b9;
  --text-dark:#1e1309;--text-mid:#4a3728;--text-soft:#7a6050;
  --radius:10px;--shadow:0 4px 24px rgba(0,0,0,.15);--shadow-sm:0 2px 10px rgba(0,0,0,.10);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* Toque sem flash azul em Android/iOS */
/* Remove o highlight padrão do SO apenas em elementos que têm
   feedback visual próprio definido explicitamente abaixo */
button,a,[role="option"]{-webkit-tap-highlight-color:transparent;}

/* ── Feedback visual de toque / clique (substitui o tap-highlight) ── */
/* Todos os botões */
button:active:not(:disabled){
  opacity:.82;
  transform:scale(.97);
  transition:opacity .08s,transform .08s;
}
/* Links */
a:active{
  opacity:.7;
  transition:opacity .08s;
}
/* Itens de lista/option */
[role="option"]:active{
  filter:brightness(.88);
  transition:filter .08s;
}

/* ── Focus visível — teclado e tecnologia assistiva ── */
/* Base: qualquer elemento focável */
:focus-visible{
  outline:2px solid var(--crop);
  outline-offset:3px;
  border-radius:4px;
}
/* Botões e links: anel dourado mais espesso */
button:focus-visible,
a:focus-visible,
[role="option"]:focus-visible{
  outline:3px solid var(--gold);
  outline-offset:3px;
  border-radius:5px;
  box-shadow:0 0 0 5px rgba(212,168,67,.25);
}
/* Inputs e selects: mantém outline colorido sem box-shadow duplo */
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:2px solid var(--crop);
  outline-offset:0;
  border-radius:4px;
  box-shadow:0 0 0 4px rgba(74,124,63,.2);
}
/* Fonte mínima 16px nos inputs evita zoom automático do iOS */
input,select,textarea{font-size:max(16px,1em);}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',sans-serif;background:var(--warm);color:var(--text-dark);overflow-x:hidden;
  /* viewport-fit=cover: garante que o conteúdo não encoste em notch/cantos arredondados */
  padding-left:env(safe-area-inset-left);
  padding-right:env(safe-area-inset-right);
}

#topbar{background:var(--soil);color:var(--gold-light);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.42rem 1rem;padding-top:calc(.42rem + env(safe-area-inset-top));display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem;border-bottom:3px solid var(--gold);}
.tb-right{display:flex;align-items:center;gap:.8rem;font-size:.72rem;color:rgba(255,255,255,.65);}

/* ══ BARRA DE COTAÇÕES ══ */
#cotacoes-bar{background:linear-gradient(90deg,#1a0f06 0%,#2c1a08 50%,#1a0f06 100%);border-bottom:1px solid rgba(255,195,70,.2);padding:.38rem 1rem;display:flex;align-items:center;gap:0;overflow:hidden;}
.cotacoes-label{font-size:.62rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;flex-shrink:0;padding-right:.85rem;border-right:1px solid rgba(255,195,70,.2);margin-right:.85rem;white-space:nowrap;}
/* cidade badge estático fora do ticker */
#cot-cidade-badge{display:inline-flex;align-items:center;gap:.35rem;background:rgba(255,195,70,.12);border:1px solid rgba(255,195,70,.25);border-radius:4px;padding:.08rem .5rem;font-size:.6rem;font-weight:700;color:var(--gold);white-space:nowrap;flex-shrink:0;margin-right:.65rem;}
/* wrapper com overflow hidden para o marquee */
.cotacoes-ticker-wrap{flex:1;overflow:hidden;position:relative;}
.cotacoes-ticker-wrap::before,.cotacoes-ticker-wrap::after{content:'';position:absolute;top:0;bottom:0;width:20px;z-index:2;pointer-events:none;}
.cotacoes-ticker-wrap::before{left:0;background:linear-gradient(to right,#1a0f06,transparent);}
.cotacoes-ticker-wrap::after{right:0;background:linear-gradient(to left,#1a0f06,transparent);}
/* faixa animada — duplicada internamente pelo JS para loop contínuo */
.cotacoes-ticker{display:inline-flex;gap:1.6rem;align-items:center;white-space:nowrap;animation:marquee-cot 32s linear infinite;}
.cotacoes-ticker:hover{animation-play-state:paused;}
@keyframes marquee-cot{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.cot-item{display:inline-flex;align-items:center;gap:.5rem;flex-shrink:0;}
.cot-name{font-size:.66rem;font-weight:700;color:rgba(255,255,255,.5);white-space:nowrap;}
.cot-price{font-size:.78rem;font-weight:700;color:#fff;font-family:'Merriweather',serif;white-space:nowrap;}
.cot-var{font-size:.62rem;font-weight:700;padding:.06rem .38rem;border-radius:4px;white-space:nowrap;}
.cot-var.up{background:rgba(39,174,96,.22);color:#6fcf97;}
.cot-var.dn{background:rgba(192,57,43,.22);color:#f47b7b;}
.cot-var.eq{background:rgba(255,255,255,.08);color:rgba(255,255,255,.45);}
.cot-sep{width:1px;height:14px;background:rgba(255,195,70,.15);flex-shrink:0;display:inline-block;vertical-align:middle;}
.cot-ts{font-size:.57rem;color:rgba(255,255,255,.22);white-space:nowrap;flex-shrink:0;margin-left:.85rem;padding-left:.85rem;border-left:1px solid rgba(255,195,70,.1);}
.cot-loading{font-size:.68rem;color:rgba(255,255,255,.3);font-style:italic;animation:pulse-simple 1.4s ease-in-out infinite;}
@media(max-width:680px){
  #cotacoes-bar{padding:.3rem .65rem;}
  .cotacoes-label{font-size:.57rem;padding-right:.55rem;margin-right:.55rem;}
  .cot-price{font-size:.73rem;}
  .cot-name{font-size:.6rem;}
  .cot-ts{display:none;}
  #cot-cidade-badge{display:none;}
}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:#6aff6a;animation:pulse 2s ease-in-out infinite;display:inline-block;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.65)}}
#tb-refresh{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:.15rem .6rem;display:flex;align-items:center;gap:.35rem;}

header{background:linear-gradient(135deg,var(--soil) 0%,#1a3a5c 100%);padding:1.9rem 1.5rem 1.5rem;position:relative;overflow:hidden;}
header::after{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 80% at 85% 50%,rgba(212,168,67,.07) 0%,transparent 70%);}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1.3rem;position:relative;z-index:1;flex-wrap:wrap;}
.logo-mark{width:58px;height:58px;flex-shrink:0;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:2px;box-shadow:0 0 0 4px rgba(212,168,67,.22),0 4px 16px rgba(0,0,0,.3);}
.logo-mark img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;}
.brand h1{font-family:'Merriweather',serif;font-size:1.9rem;font-weight:900;color:var(--white);line-height:1.05;text-shadow:0 2px 8px rgba(0,0,0,.4);}
.brand-sub{font-size:.72rem;font-weight:400;color:rgba(255,255,255,.5);letter-spacing:.02em;display:block;margin-top:.18rem;}
@media(max-width:600px){.brand-sub{display:none;}}

/* H2 section-title — semântico para SEO, visual idêntico ao div anterior */
h2.section-title,
.section-title{font-family:'Merriweather',serif;font-size:1.1rem;font-weight:700;color:var(--soil);border-left:5px solid var(--gold);padding-left:.75rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;}
h2.section-title .e,
.section-title .e{font-size:1.25rem;}

.brand p{font-size:.82rem;color:rgba(255,255,255,.62);margin-top:.28rem;letter-spacing:.04em;}
.header-right{margin-left:auto;text-align:right;}
#clock{font-family:'Merriweather',serif;font-size:1.45rem;font-weight:700;color:var(--gold-light);}
#date-label{font-size:.72rem;color:rgba(255,255,255,.52);margin-top:.12rem;}
#last-update{font-size:.68rem;color:rgba(255,255,255,.4);margin-top:.18rem;}

/* ══ MENU PRIMÁRIO ══ */
#nav-primary{background:linear-gradient(90deg,#1a0f06 0%,#2c1810 50%,#1a0f06 100%);border-bottom:2px solid rgba(212,168,67,.35);z-index:99;box-shadow:0 2px 12px rgba(0,0,0,.3);overflow-x:auto;-webkit-overflow-scrolling:touch;}
#nav-primary::-webkit-scrollbar{height:0;}
.nav-primary-inner{max-width:1200px;margin:0 auto;display:flex;align-items:stretch;justify-content:flex-end;gap:0;padding:0 .6rem;min-width:max-content;}
.nav-primary-link{color:rgba(255,255,255,.75);font-size:.73rem;font-weight:700;letter-spacing:.05em;text-decoration:none;padding:.5rem 1rem;display:flex;align-items:center;gap:.38rem;text-transform:uppercase;white-space:nowrap;border-bottom:2px solid transparent;transition:color .18s,border-color .18s,background .18s;}
.nav-primary-link:hover{color:var(--gold-light);border-bottom-color:var(--gold);background:rgba(212,168,67,.08);}
@media(max-width:480px){
  .nav-primary-inner{justify-content:flex-start;}
  .nav-primary-link{padding:.46rem .65rem;font-size:.67rem;letter-spacing:.02em;}
}

/* ══ MENU SECUNDÁRIO — scroll horizontal no mobile, sem quebra ══ */
#nav-secondary{background:var(--soil-mid);border-bottom:4px solid var(--gold);position:sticky;top:0;z-index:100;box-shadow:var(--shadow);overflow-x:auto;-webkit-overflow-scrolling:touch;}
#nav-secondary::-webkit-scrollbar{height:3px;}
#nav-secondary::-webkit-scrollbar-thumb{background:rgba(212,168,67,.45);border-radius:3px;}
#nav-secondary::-webkit-scrollbar-track{background:transparent;}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;flex-wrap:nowrap;gap:.2rem;padding:.42rem .8rem;min-width:max-content;}
#nav-secondary a{color:var(--gold-light);font-size:.73rem;font-weight:700;letter-spacing:.04em;text-decoration:none;padding:.34rem .7rem;border-radius:5px;transition:background .18s,color .18s;text-transform:uppercase;white-space:nowrap;flex-shrink:0;}
#nav-secondary a:hover,#nav-secondary a.active{background:var(--gold);color:var(--soil);}
@media(max-width:480px){
  #nav-secondary a{font-size:.68rem;padding:.3rem .55rem;}
  .nav-inner{gap:.15rem;padding:.36rem .55rem;}
}
/* legacy selectors — mantidos para não quebrar JS existente */
nav a{color:var(--gold-light);font-size:.73rem;font-weight:700;letter-spacing:.04em;text-decoration:none;padding:.34rem .7rem;border-radius:5px;transition:background .18s,color .18s;text-transform:uppercase;white-space:nowrap;}
nav a:hover,nav a.active{background:var(--gold);color:var(--soil);}
nav a.nav-noticias{background:var(--crop);color:var(--white);border-radius:5px;}
nav a.nav-noticias:hover{background:var(--crop-bright);color:var(--white);}

main{max-width:1200px;margin:1.7rem auto;padding:0 1.1rem;}
section{margin-bottom:2.3rem;}

/* SELECTOR */
.selector-box{background:var(--white);border:2px solid var(--gold);border-radius:var(--radius);padding:1.2rem 1.4rem;box-shadow:var(--shadow);}
.selector-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.85rem;margin-bottom:.85rem;}
.selector-box label{font-weight:700;color:var(--soil);font-size:.9rem;white-space:nowrap;display:block;margin-bottom:.3rem;}

/* ══ AUTOCOMPLETE MUNICÍPIO ══ */
.ac-wrap{position:relative;flex:1;min-width:260px;}
#ac-input{width:100%;padding:.65rem 1rem .65rem 2.4rem;border:2px solid var(--soil-light);border-radius:7px;font-family:'Source Sans 3',sans-serif;font-size:.95rem;font-weight:600;color:var(--text-dark);background:var(--warm);transition:border-color .18s;-webkit-appearance:none;}
#ac-input:focus{outline:none;border-color:var(--crop);background:#fff;}
.ac-search-icon{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);font-size:1rem;pointer-events:none;z-index:1;}
.ac-wrap .ac-clear{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1rem;color:var(--text-soft);cursor:pointer;display:none;padding:.15rem;line-height:1;}
.ac-wrap .ac-clear:hover{color:var(--danger);}
#ac-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:2px solid var(--crop);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.18);z-index:500;max-height:320px;overflow-y:auto;overflow-x:hidden;}
#ac-dropdown::-webkit-scrollbar{width:5px;}
#ac-dropdown::-webkit-scrollbar-thumb{background:var(--soil-light);border-radius:5px;}
.ac-group-label{padding:.38rem .9rem .22rem;font-size:.63rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid #f0e8e0;background:#fdfaf5;position:sticky;top:0;}
.ac-item{display:flex;align-items:center;gap:.6rem;padding:.6rem .9rem;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-dark);transition:background .1s;}
.ac-item:hover,.ac-item.ac-active{background:var(--warm);}
.ac-item.ac-selected{background:#edfaf3;color:#1a6e3a;}
.ac-item-star{font-size:.8rem;opacity:.6;}
.ac-highlight{background:#fff3b0;border-radius:2px;font-weight:800;}
.ac-empty{padding:.85rem 1rem;color:var(--text-soft);font-size:.85rem;text-align:center;}
.ac-item-dist{margin-left:auto;font-size:.65rem;color:var(--text-soft);font-weight:400;white-space:nowrap;}

/* Esconde o select antigo mas mantém no DOM */
#city-search-old-wrap{display:none;}
#city-select{display:none;}
#btn-buscar{padding:.62rem 1.5rem;background:var(--crop);color:var(--white);border:none;border-radius:7px;font-family:'Source Sans 3',sans-serif;font-size:.92rem;font-weight:700;cursor:pointer;transition:background .2s,transform .1s;display:flex;align-items:center;gap:.45rem;white-space:nowrap;}
#btn-buscar:hover{background:var(--crop-bright);}
#btn-buscar:disabled{opacity:.5;cursor:not-allowed;}
.selector-meta{font-size:.75rem;color:var(--text-soft);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;}
.source-badge{display:inline-flex;align-items:center;gap:.3rem;background:rgba(27,162,79,.1);border:1px solid rgba(27,162,79,.3);border-radius:20px;padding:.18rem .65rem;font-size:.7rem;font-weight:700;color:var(--crop);}
.countdown-wrap{display:flex;align-items:center;gap:.55rem;font-size:.78rem;color:var(--text-soft);margin-left:auto;}
#cd-ring{position:relative;width:30px;height:30px;flex-shrink:0;}
#cd-ring svg{transform:rotate(-90deg);}
#cd-ring circle.bg{fill:none;stroke:#ddd;stroke-width:3;}
#cd-ring circle.prog{fill:none;stroke:var(--crop);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset 1s linear;}
#cd-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:700;color:var(--crop);}

#loading{display:none;text-align:center;padding:2rem;color:var(--text-soft);font-size:.9rem;}
.spinner-lg{display:inline-block;width:34px;height:34px;border:3px solid rgba(61,43,31,.14);border-top-color:var(--crop);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:.55rem;}
/* ══ ANIMAÇÕES LEVES — substituem as pesadas ══ */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes pulse-simple{0%,100%{opacity:1}50%{opacity:.4}}

/* Respeita preferência de SO por menos movimento */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important;}
}

/* Dispositivos lentos (heurística: telas pequenas provavelmente = celular básico) */
@media(max-width:480px){
  .card{animation:none;box-shadow:0 2px 8px rgba(0,0,0,.1);}
  .cal-card,.tip{animation:none;}
  .alert-box{animation:none;}
  .rain-bar-fill{transition:none;}
  .fc-day:hover{transform:none;}
  .pulv-hero-inner::after{display:none;}
}

/* ══ BANNER OFFLINE ══ */
#offline-banner{display:none;position:sticky;top:0;z-index:200;background:linear-gradient(135deg,#7a4a00,#c0392b);color:#fff;text-align:center;padding:.55rem 1rem;font-size:.82rem;font-weight:700;letter-spacing:.02em;border-bottom:2px solid rgba(255,255,255,.2);}
#offline-banner span{background:rgba(0,0,0,.2);border-radius:20px;padding:.15rem .65rem;margin-left:.6rem;font-size:.72rem;font-weight:400;}

/* ══ DADOS DESATUALIZADOS ══ */
#stale-badge{display:none;background:#fff3cd;border:1px solid #ffc107;border-radius:20px;padding:.2rem .75rem;font-size:.72rem;font-weight:700;color:#856404;margin-left:.5rem;}

/* ══ MONITOR VERANICO ══ */
#veranico-monitor{display:none;border-radius:var(--radius);margin-bottom:1.1rem;overflow:hidden;}
.veranico-inner{padding:1.1rem 1.4rem;display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap;}
#veranico-monitor.veranico-ok .veranico-inner{background:#edfaf3;border:2px solid var(--ok);}
#veranico-monitor.veranico-alerta .veranico-inner{background:linear-gradient(135deg,#fff8e1,#fef3c7);border:2px solid #f59e0b;}
#veranico-monitor.veranico-critico .veranico-inner{background:linear-gradient(135deg,#fff1f1,#fde8e8);border:2px solid var(--danger);animation:pisca 2.5s ease-in-out infinite;}
@keyframes pisca{0%,100%{border-color:var(--danger)}50%{border-color:rgba(192,57,43,.35)}}
@media(prefers-reduced-motion:reduce){#veranico-monitor.veranico-critico .veranico-inner{animation:none;}}
.veranico-icone{font-size:2.4rem;line-height:1;flex-shrink:0;}
.veranico-content{flex:1;min-width:0;}
.veranico-titulo{font-family:'Merriweather',serif;font-size:1rem;font-weight:900;margin-bottom:.28rem;}
#veranico-monitor.veranico-ok .veranico-titulo{color:#1a6e3a;}
#veranico-monitor.veranico-alerta .veranico-titulo{color:#92400e;}
#veranico-monitor.veranico-critico .veranico-titulo{color:var(--danger);}
.veranico-corpo{font-size:.84rem;color:var(--text-mid);line-height:1.6;}
.veranico-barra-wrap{margin-top:.7rem;display:flex;gap:4px;align-items:flex-end;height:36px;}
.veranico-dia{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;}
.veranico-barra{width:100%;border-radius:3px 3px 0 0;min-height:4px;transition:height .3s ease;}
.veranico-dlbl{font-size:.58rem;color:var(--text-soft);font-weight:700;text-transform:uppercase;}
.veranico-badge{display:inline-flex;align-items:center;gap:.3rem;border-radius:20px;padding:.18rem .7rem;font-size:.72rem;font-weight:700;margin-top:.5rem;}
.badge-seco{background:#fef3c7;color:#92400e;border:1px solid #f59e0b;}
.badge-chuva{background:#e0f2fe;color:#075985;border:1px solid #38bdf8;}
.badge-ok{background:#dcfce7;color:#14532d;border:1px solid #4ade80;}


/* ══ CONSULTOR IA — ESTÉTICA CAMPO ══ */
.ai-box{
  background:linear-gradient(160deg,#1c2e12 0%,#2a1a08 55%,#1a2c10 100%);
  border-radius:var(--radius);
  padding:1.6rem 1.8rem;
  color:#fff;
  position:relative;
  overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.25);
  border:1px solid rgba(160,200,80,.15);
}
/* Textura de fundo sutil — lavoura */
.ai-box::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(
      90deg,
      rgba(80,140,30,.03) 0px,
      rgba(80,140,30,.03) 1px,
      transparent 1px,
      transparent 28px
    ),
    repeating-linear-gradient(
      0deg,
      rgba(80,140,30,.03) 0px,
      rgba(80,140,30,.03) 1px,
      transparent 1px,
      transparent 28px
    );
  pointer-events:none;
}
.ai-box::after{
  content:'🌾';
  position:absolute;
  right:1.5rem;
  bottom:.8rem;
  font-size:6rem;
  opacity:.05;
  pointer-events:none;
  line-height:1;
}
.ai-box-header{display:flex;align-items:center;gap:.95rem;flex-wrap:wrap;margin-bottom:1.25rem;}
.ai-avatar{
  width:48px;height:48px;flex-shrink:0;
  background:linear-gradient(135deg,#4a7c3f,#c8821a);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;
  box-shadow:0 3px 12px rgba(0,0,0,.3);
}
.ai-box h3{
  font-family:'Merriweather',serif;
  font-size:1rem;
  color:var(--gold-light);
  margin:0 0 .22rem;
}
.ai-context-pill{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px;
  padding:.2rem .7rem;
  font-size:.7rem;
  color:rgba(255,255,255,.6);
}
.ai-context-pill.active{
  background:rgba(106,175,92,.2);
  border-color:rgba(106,175,92,.4);
  color:#9cd989;
}

/* Cards automáticos */
#ai-auto-wrap{margin-bottom:1.15rem;}
.ai-auto-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem;margin-bottom:.6rem;}
@media(max-width:700px){.ai-auto-cards{grid-template-columns:1fr;}}
.ai-auto-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;
  padding:.85rem 1rem;
  display:flex;gap:.7rem;align-items:flex-start;
  transition:background .2s;
}
.ai-auto-card:hover{background:rgba(255,255,255,.09);}
.ai-auto-icon{font-size:1.5rem;line-height:1;flex-shrink:0;margin-top:.08rem;}
.ai-auto-body{flex:1;min-width:0;}
.ai-auto-q{
  font-size:.65rem;font-weight:700;
  color:var(--gold-light);
  text-transform:uppercase;letter-spacing:.07em;
  margin-bottom:.32rem;
}
.ai-auto-a{font-size:.84rem;color:rgba(255,255,255,.88);line-height:1.6;}
.ai-auto-a.loading{
  color:rgba(255,255,255,.3);font-style:italic;
  display:flex;align-items:center;gap:.4rem;
}
.ai-auto-a.loading::before{
  content:'';
  display:inline-block;width:9px;height:9px;
  border:2px solid rgba(255,255,255,.15);
  border-top-color:var(--gold-light);
  border-radius:50%;
  animation:spin .8s linear infinite;
  flex-shrink:0;
}
.ai-auto-refresh{
  background:none;
  border:1px solid rgba(255,255,255,.15);
  border-radius:20px;
  color:rgba(255,255,255,.45);
  font-size:.7rem;
  padding:.28rem .85rem;
  cursor:pointer;
  transition:all .18s;
  min-height:36px;
}
.ai-auto-refresh:hover{background:rgba(255,255,255,.09);color:rgba(255,255,255,.8);}
.ai-auto-refresh:disabled{opacity:.3;cursor:not-allowed;}

/* Divisor */
.ai-divider{
  display:flex;align-items:center;gap:.7rem;
  margin:1.1rem 0 .85rem;
}
.ai-divider::before,.ai-divider::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
}
.ai-divider span{font-size:.67rem;color:rgba(255,255,255,.45);white-space:nowrap;letter-spacing:.06em;}

/* Sugestões */
.ai-suggestions{display:flex;flex-wrap:wrap;gap:.38rem;margin-bottom:.8rem;}
.ai-sug{
  background:rgba(200,130,26,.12);
  border:1px solid rgba(200,130,26,.25);
  border-radius:20px;
  padding:.3rem .85rem;
  font-size:.74rem;
  color:rgba(255,220,140,.85);
  cursor:pointer;
  transition:background .15s,border-color .15s;
  white-space:nowrap;
  -webkit-tap-highlight-color:transparent;
  position:relative;
  min-height:36px;
  display:inline-flex;align-items:center;
}
.ai-sug:active{background:rgba(200,130,26,.35);border-color:rgba(200,130,26,.6);transform:scale(.96);}
.ai-sug::before{content:'';position:absolute;inset:-6px -4px;}
.ai-sug:hover{background:rgba(200,130,26,.25);border-color:rgba(200,130,26,.45);color:#fff;}

/* Input */
.ai-input-row{display:flex;gap:.6rem;flex-wrap:wrap;}
#ai-question{
  flex:1;min-width:200px;
  padding:.72rem 1rem;
  border-radius:8px;
  border:1.5px solid rgba(160,200,80,.25);
  font-family:'Source Sans 3',sans-serif;
  font-size:.95rem;
  background:rgba(255,255,255,.07);
  color:#fff;
  outline:none;
  transition:border-color .2s,background .2s;
  min-height:48px;
}
#ai-question::placeholder{color:rgba(255,255,255,.3);}
#ai-question:focus{
  background:rgba(255,255,255,.11);
  border-color:rgba(160,200,80,.55);
  box-shadow:0 0 0 3px rgba(160,200,80,.1);
}
#btn-ai{
  padding:.72rem 1.4rem;
  background:linear-gradient(135deg,#c8821a,#e5a020);
  color:#fff;
  border:none;border-radius:8px;
  font-weight:700;font-size:.95rem;
  cursor:pointer;
  transition:all .18s;
  white-space:nowrap;
  min-height:48px;min-width:120px;
  box-shadow:0 4px 14px rgba(200,130,26,.35);
  display:flex;align-items:center;justify-content:center;gap:.4rem;
}
#btn-ai:hover{background:linear-gradient(135deg,#d99020,#f0b030);transform:translateY(-1px);box-shadow:0 6px 18px rgba(200,130,26,.45);}
#btn-ai:active{transform:translateY(0) scale(.97);box-shadow:none;}
#btn-ai:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;}

/* Área de resposta */
#ai-answer{
  margin-top:.95rem;
  background:rgba(0,0,0,.28);
  border-radius:10px;
  padding:1rem 1.2rem;
  font-size:.85rem;
  line-height:1.7;
  display:none;
  color:rgba(255,255,255,.9);
  border-left:3px solid var(--gold);
}
.ai-spin{
  display:inline-block;width:14px;height:14px;
  border:2px solid rgba(255,255,255,.2);
  border-top-color:var(--gold-light);
  border-radius:50%;
  animation:spin .7s linear infinite;
  vertical-align:middle;margin-right:.4rem;
}
.ai-context-badge{
  display:inline-flex;align-items:center;gap:.35rem;
  background:rgba(106,175,92,.15);
  border:1px solid rgba(106,175,92,.3);
  border-radius:6px;
  padding:.18rem .6rem;
  font-size:.67rem;
  color:#9cd989;
  margin-bottom:.6rem;
}
.ai-answer-header{
  font-family:'Merriweather',serif;
  font-size:.82rem;
  color:var(--gold-light);
  font-weight:700;
  margin-bottom:.5rem;
  display:flex;align-items:center;gap:.4rem;
}
.ai-answer-body{font-size:.84rem;color:rgba(255,255,255,.88);line-height:1.72;}
.ai-answer-body p{margin:.5rem 0;}
.ai-answer-body strong{color:var(--gold-light);}

.ai-auto-grid{display:none;}
#ai-auto-label{display:none;}

#error-msg{display:none;background:#fdf0ef;border:1px solid var(--danger);border-radius:var(--radius);padding:.9rem 1.3rem;color:var(--danger);font-weight:600;}
.status-bar{background:var(--white);border-radius:var(--radius);padding:.65rem 1.1rem;margin-bottom:1.1rem;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;border-left:5px solid var(--crop);}
.status-city{font-family:'Merriweather',serif;font-weight:700;font-size:1rem;color:var(--soil);}
.status-time{font-size:.78rem;color:var(--text-soft);margin-left:auto;}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);}
.status-coords{font-size:.68rem;color:var(--text-soft);}

.weather-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
@media(max-width:680px){.weather-grid{grid-template-columns:1fr;}}
.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.2rem 1.4rem;border-top:4px solid var(--gold);animation:fadeUp .4s ease both;}
.card.full{grid-column:1/-1;}
.card h3{font-family:'Merriweather',serif;font-size:.9rem;font-weight:700;color:var(--soil);margin-bottom:.85rem;display:flex;align-items:center;gap:.42rem;}

.temp-main{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;}
.temp-big{font-family:'Merriweather',serif;font-size:3.5rem;font-weight:900;color:var(--sky);line-height:1;}
.wi-icon-big{font-size:3.2rem;line-height:1;}
.temp-desc{font-size:1rem;font-weight:600;color:var(--text-mid);margin-top:.18rem;}
.temp-minmax{font-size:.82rem;color:var(--text-soft);margin-top:.12rem;}

.metric-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(115px,1fr));gap:.6rem;margin-top:.45rem;}
.metric{background:var(--warm);border-radius:8px;padding:.65rem .85rem;}
.metric-label{font-size:.66rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;}
.metric-val{font-size:1.15rem;font-weight:700;color:var(--sky);margin-top:.08rem;}
.metric-unit{font-size:.68rem;color:var(--text-soft);}

.chart-wrap{position:relative;width:100%;height:200px;margin-top:.5rem;}
canvas#tempChart{width:100%;height:200px;}
.chart-legend{display:flex;gap:1.2rem;margin-top:.6rem;flex-wrap:wrap;}
.legend-item{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--text-mid);}
.legend-dot{width:12px;height:4px;border-radius:2px;}

.forecast-strip{display:flex;gap:.55rem;overflow-x:auto;padding-bottom:.45rem;}
.forecast-strip::-webkit-scrollbar{height:4px;}
.forecast-strip::-webkit-scrollbar-thumb{background:var(--soil-light);border-radius:4px;}
.fc-day{min-width:72px;background:var(--warm);border-radius:8px;padding:.6rem .5rem;text-align:center;flex-shrink:0;transition:transform .15s;}
.fc-day:hover{transform:translateY(-2px);}
.fc-day.today{background:var(--sky);}
.fc-label{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-soft);}
.fc-day.today .fc-label{color:rgba(255,255,255,.7);}
.fc-icon{font-size:1.45rem;margin:.22rem 0;}
.fc-temp{font-family:'Merriweather',serif;font-size:.9rem;font-weight:700;color:var(--sky);}
.fc-day.today .fc-temp{color:var(--gold-light);}
.fc-sub{font-size:.6rem;color:var(--text-soft);margin-top:.12rem;}
.fc-day.today .fc-sub{color:rgba(255,255,255,.55);}

.hourly-strip{display:flex;gap:.45rem;overflow-x:auto;padding-bottom:.35rem;margin-top:.35rem;}
.hourly-strip::-webkit-scrollbar{height:3px;}
.hourly-strip::-webkit-scrollbar-thumb{background:var(--soil-light);border-radius:3px;}
.hr-item{min-width:50px;background:var(--warm);border-radius:7px;padding:.45rem .38rem;text-align:center;flex-shrink:0;}
.hr-time{font-size:.62rem;color:var(--text-soft);font-weight:700;}
.hr-icon{font-size:1.05rem;margin:.18rem 0;}
.hr-temp{font-size:.78rem;font-weight:700;color:var(--sky);}
.hr-rain{font-size:.6rem;color:var(--sky-light);}

.rain-bar-wrap{display:flex;flex-direction:column;gap:.38rem;margin-top:.4rem;}
.rain-row{display:flex;align-items:center;gap:.55rem;font-size:.76rem;}
.rain-label{width:34px;text-align:right;color:var(--text-soft);font-size:.68rem;}
.rain-bar-bg{flex:1;height:11px;background:#e8ddd4;border-radius:6px;overflow:hidden;}
.rain-bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--sky-light),var(--sky));transition:width .6s ease;}
.rain-val{width:36px;font-weight:700;color:var(--sky);font-size:.7rem;}

.alert-box{border-radius:var(--radius);padding:.85rem 1.1rem;margin-bottom:.72rem;display:flex;align-items:flex-start;gap:.65rem;border-left:5px solid;}
.alert-box.danger{background:#fdf0ef;border-color:var(--danger);}
.alert-box.warn{background:#fef6ec;border-color:var(--warn);}
.alert-box.ok{background:#edfaf3;border-color:var(--ok);}
.alert-box.info{background:#eaf4fb;border-color:var(--info);}
.alert-icon{font-size:1.2rem;flex-shrink:0;margin-top:.08rem;}
.alert-title{font-weight:700;font-size:.88rem;}
.alert-body{font-size:.8rem;color:var(--text-mid);margin-top:.12rem;line-height:1.5;}

.pulv-badge{display:inline-flex;align-items:center;gap:.45rem;padding:.45rem 1rem;border-radius:7px;color:#fff;font-weight:700;font-size:.9rem;margin-bottom:.6rem;}
.pulv-criteria{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:.45rem;margin-top:.45rem;}
.crit{background:var(--warm);border-radius:7px;padding:.45rem .65rem;font-size:.73rem;display:flex;align-items:flex-start;gap:.38rem;}
.crit-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:.22rem;}
#pulv-janela-wrap{border-top:1px solid #f0e8e0;padding-top:.85rem;}
@media(max-width:480px){#pulv-janela-wrap>div:first-child+div{grid-template-columns:repeat(auto-fill,minmax(58px,1fr));}}

.calendar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.95rem;}
.cal-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;animation:fadeUp .5s ease both;}
.cal-head{padding:.62rem .95rem;font-weight:700;font-size:.86rem;color:var(--white);display:flex;align-items:center;gap:.42rem;}
.cal-body{padding:.7rem .95rem;font-size:.8rem;color:var(--text-mid);line-height:1.55;}
.cal-card.soja .cal-head{background:#4a7c3f;}
.cal-card.milho .cal-head{background:#c8821a;}
.cal-card.algodao .cal-head{background:#7b6fa0;}
.cal-card.boi .cal-head{background:#7a3d2c;}
.cal-card.sorgo .cal-head{background:#5a7a1a;color:#fff;}

.tips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:.95rem;}
.tip{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.05rem;border-top:3px solid var(--crop);animation:fadeUp .5s ease both;}
.tip-icon{font-size:1.6rem;margin-bottom:.38rem;}
.tip-title{font-family:'Merriweather',serif;font-size:.87rem;font-weight:700;color:var(--soil);margin-bottom:.32rem;}
.tip-body{font-size:.78rem;color:var(--text-mid);line-height:1.55;}

.map-banner{background:linear-gradient(120deg,#c8e8b0 0%,#6aaf5c 50%,#4a7c3f 100%);border-radius:var(--radius);padding:1.4rem 1.8rem;display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;box-shadow:var(--shadow);border:2px solid var(--crop);}
.map-mt{font-size:3.2rem;opacity:.25;font-family:'Merriweather',serif;font-weight:900;}
.map-text h4{font-family:'Merriweather',serif;font-size:1rem;font-weight:700;color:var(--soil);}
.map-text p{font-size:.8rem;color:var(--soil-mid);margin-top:.28rem;line-height:1.5;}
.map-stats{margin-left:auto;display:flex;gap:.85rem;flex-wrap:wrap;}
.mstat{background:rgba(255,255,255,.58);border-radius:8px;padding:.55rem .9rem;text-align:center;}
.mstat-val{font-family:'Merriweather',serif;font-size:1.2rem;font-weight:900;color:var(--soil);}
.mstat-lbl{font-size:.64rem;color:var(--soil-mid);font-weight:700;text-transform:uppercase;letter-spacing:.04em;}

/* ══ HISTÓRICO CLIMÁTICO ══ */
.hist-placeholder{background:var(--white);border:2px dashed #d4c4b4;border-radius:var(--radius);padding:2.2rem 1.5rem;text-align:center;color:var(--text-soft);}
.hist-placeholder-icon{font-size:2.2rem;margin-bottom:.6rem;}
.hist-placeholder-txt{font-size:.88rem;line-height:1.5;}
.hist-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.9rem;}
.hist-city-label{font-family:'Merriweather',serif;font-size:1.05rem;font-weight:700;color:var(--soil);}
.hist-badges{display:flex;gap:.5rem;flex-wrap:wrap;}
.hist-badge{display:inline-flex;align-items:center;gap:.35rem;border-radius:20px;padding:.28rem .85rem;font-size:.74rem;font-weight:700;}
.hist-badge.acima{background:#fef9ec;border:1.5px solid var(--warn);color:#b36a00;}
.hist-badge.abaixo{background:#eaf4fb;border:1.5px solid var(--info);color:#1a5276;}
.hist-badge.normal{background:#edfaf3;border:1.5px solid var(--ok);color:#1a6e3a;}
.hist-badge.seco{background:#fdf0ef;border:1.5px solid var(--danger);color:#922b21;}
.hist-summary-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:.75rem;}
.hist-sum-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:.95rem 1.1rem;border-top:4px solid var(--gold);position:relative;overflow:hidden;}
.hist-sum-label{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-soft);margin-bottom:.22rem;}
.hist-sum-val{font-family:'Merriweather',serif;font-size:1.35rem;font-weight:900;color:var(--sky);}
.hist-sum-unit{font-size:.68rem;color:var(--text-soft);margin-left:.2rem;}
.hist-sum-vs{font-size:.74rem;font-weight:700;margin-top:.28rem;}
.hist-sum-vs.acima{color:var(--warn);}
.hist-sum-vs.abaixo{color:var(--info);}
.hist-sum-vs.normal{color:var(--ok);}
.hist-sum-vs.seco{color:var(--danger);}
.hist-sum-bar{position:absolute;bottom:0;left:0;height:3px;background:var(--gold);transition:width .8s ease;}
@media(max-width:480px){.hist-summary-row{grid-template-columns:1fr 1fr;}}

/* ══════════════════════════════════════
   ACESSIBILIDADE — ALVOS DE TOQUE 44×44px
   Diretriz Apple HIG / Google Material
   Elemento visual pode ser menor;
   área de toque invisível = 44×44px mínimo
══════════════════════════════════════ */

/* Botões principais — já grandes, garantir min-height */
#btn-buscar,#btn-ai,#btn-ai-refresh,.ai-auto-refresh{
  min-height:44px;
  min-width:44px;
}

/* Links da nav — padding para atingir 44px de altura */
nav a{
  display:inline-flex;
  align-items:center;
  min-height:44px;
  padding-top:.5rem;
  padding-bottom:.5rem;
  position:relative;
}

/* Sugestões IA — pill pequeno, pseudo-elemento expande alvo */
.ai-sug{
  position:relative;
  display:inline-flex;
  align-items:center;
}
.ai-sug::before{
  content:'';
  position:absolute;
  inset:-8px -4px;
  min-height:44px;
  min-width:44px;
}

/* Items do autocomplete — já têm min-height:48px no mobile, garantir desktop */
.ac-item{
  min-height:44px;
}

/* Botão limpar autocomplete — pequeno visualmente, alvo generoso */
.ac-wrap .ac-clear{
  min-width:44px;
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
}
/* Oculto por padrão — JS adiciona display via inline style quando há texto */
.ac-wrap .ac-clear:not([style*="display"]){display:none;}

/* Dias do forecast — min-height real definida na seção CLS (110px) */

/* Items horários — min-height real definida na seção CLS (76px) */
.hr-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}

/* Botão WhatsApp inline no hero */
.db-city-line button{
  min-height:36px; /* inline no texto, relaxado */
  padding:.25rem .75rem;
  position:relative;
}
.db-city-line button::before{
  content:'';
  position:absolute;
  inset:-4px -4px;
}

/* Cards do carrossel — toda área clicável */
.md-card{
  cursor:default;
}

/* Botão atualizar cotações — discreto mas tocável */
.ai-auto-refresh{
  padding:.5rem 1rem;
}

/* Botão refresh IA */
#btn-ai-refresh{
  padding:.5rem 1rem;
  min-height:44px;
}

/* Slots da janela de pulverização — tooltip hover */
#pulv-janela-wrap > div > div > div{
  min-height:44px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}

/* Itens de cotação — não são clicáveis, sem pseudo */

/* Badge GPS status — só display */
.gps-toast{position:fixed;bottom:calc(1.5rem + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%) translateY(120%);background:var(--soil);color:#fff;padding:.7rem 1.4rem;border-radius:30px;font-size:.83rem;font-weight:600;box-shadow:0 6px 28px rgba(0,0,0,.3);z-index:9999;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .3s;opacity:0;white-space:nowrap;}
.gps-toast.show{transform:translateX(-50%) translateY(0);opacity:1;}

/* Footer melhorado */
footer{background:var(--soil);color:rgba(255,255,255,.52);text-align:center;padding:2rem 1.5rem calc(1.5rem + env(safe-area-inset-bottom));font-size:.76rem;line-height:1.85;}
footer strong{color:var(--gold-light);}
@media(max-width:600px){footer>div>div:last-of-type{flex-direction:column;}}

/* ══ BARRA DE DECISÃO DO DIA ══ */
#decision-bar{display:none;animation:fadeUp .4s ease both;}
.db-wrap{padding:1.4rem 1.6rem 1.2rem;position:relative;overflow:hidden;}
.db-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 60%);pointer-events:none;}
#decision-bar.db-green .db-wrap{background:linear-gradient(135deg,#0d5e2a 0%,#1a8c40 100%);}
#decision-bar.db-yellow .db-wrap{background:linear-gradient(135deg,#6b3a00 0%,#c47a00 100%);}
#decision-bar.db-red .db-wrap{background:linear-gradient(135deg,#6b0a0a 0%,#b92020 100%);}
.db-top{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-bottom:1rem;}
.db-score-ring{position:relative;flex-shrink:0;}
.db-score-ring svg{transform:rotate(-90deg);}
.db-score-ring circle{fill:none;stroke-width:7;stroke-linecap:round;}
.db-score-ring .ring-bg{stroke:rgba(255,255,255,.15);}
.db-score-ring .ring-fill{stroke:rgba(255,255,255,.9);transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1);}
.db-score-num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.db-score-pct{font-family:'Merriweather',serif;font-size:1.25rem;font-weight:900;color:#fff;line-height:1;}
.db-score-lbl{font-size:.5rem;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.08em;margin-top:.1rem;}
.db-headline{flex:1;min-width:0;}
.db-question{font-size:.65rem;font-weight:700;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.2rem;}
.db-answer{font-family:'Merriweather',serif;font-size:1.5rem;font-weight:900;color:#fff;line-height:1.15;text-shadow:0 2px 8px rgba(0,0,0,.3);}
@media(max-width:500px){.db-answer{font-size:1.15rem;}}
.db-sub{font-size:.82rem;color:rgba(255,255,255,.78);margin-top:.28rem;line-height:1.5;}
.db-city-line{font-size:.7rem;color:rgba(255,255,255,.48);margin-top:.4rem;display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;}
.db-city-line strong{color:rgba(255,255,255,.72);}
.db-actions{display:flex;gap:.5rem;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.12);padding-top:.8rem;}
.db-action{background:rgba(0,0,0,.2);border-radius:8px;padding:.45rem .8rem;font-size:.77rem;color:rgba(255,255,255,.85);display:flex;align-items:center;gap:.4rem;}
.db-action.ok-action{border-left:3px solid rgba(106,215,110,.7);}
.db-action.warn-action{border-left:3px solid rgba(255,195,70,.7);}
.db-action.bad-action{border-left:3px solid rgba(255,100,100,.7);}
.db-action strong{color:#fff;}

/* ══ CARROSSEL MICRO-DECISÕES ══ */
#microdec{display:none;animation:fadeUp .45s ease .1s both;}
.md-label{font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-soft);padding:.65rem 1.6rem .3rem;display:flex;align-items:center;gap:.55rem;}
.md-label::after{content:'';flex:1;height:1px;background:#e8ddd4;}
.md-cards{display:grid;grid-template-columns:repeat(3,1fr);}
@media(max-width:680px){
  .md-cards{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
  .md-cards::-webkit-scrollbar{display:none;}
  .md-card{min-width:74vw;scroll-snap-align:start;flex-shrink:0;}
}
.md-card{background:#fff;border-right:1px solid #f0e8e0;border-bottom:4px solid transparent;padding:1.1rem 1.3rem 1rem;transition:background .18s;}
.md-card:last-child{border-right:none;}
.md-card.md-green{border-bottom-color:#27ae60;background:linear-gradient(180deg,#fff 60%,#f0faf4);}
.md-card.md-yellow{border-bottom-color:#e67e22;background:linear-gradient(180deg,#fff 60%,#fdf6ec);}
.md-card.md-red{border-bottom-color:#c0392b;background:linear-gradient(180deg,#fff 60%,#fdf0ef);}
.md-icon{font-size:2.1rem;line-height:1;margin-bottom:.4rem;}
.md-topic{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);margin-bottom:.15rem;}
.md-decision{font-family:'Merriweather',serif;font-size:1.3rem;font-weight:900;line-height:1.1;}
.md-card.md-green .md-decision{color:#1a6e3a;}
.md-card.md-yellow .md-decision{color:#7a4a00;}
.md-card.md-red .md-decision{color:#a32d2d;}
.md-detail{font-size:.74rem;color:var(--text-mid);margin-top:.28rem;line-height:1.5;}
.md-badge{display:inline-flex;align-items:center;gap:.3rem;border-radius:20px;padding:.15rem .6rem;font-size:.65rem;font-weight:700;margin-top:.42rem;}
.md-badge.g{background:#dcfce7;color:#14532d;}
.md-badge.y{background:#fef3c7;color:#92400e;}
.md-badge.r{background:#fee2e2;color:#7f1d1d;}
.md-scroll-hint{display:none;text-align:center;font-size:.65rem;color:var(--text-soft);padding:.3rem;letter-spacing:.04em;}
@media(max-width:680px){.md-scroll-hint{display:block;}}

/* pulv-hero legado — mantido para compatibilidade JS */
#pulv-hero{display:none!important;}
.pulv-hero-inner,.pulv-hero-metrics,.ph-metric,.ph-metrics{display:none!important;}

/* ══ LOADING SKELETON ══ */
#skeleton{display:none;padding:1.2rem 1.1rem;}
.skel-row{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap;}
.skel-block{background:linear-gradient(90deg,#e8ddd4 25%,#f5ede0 50%,#e8ddd4 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:8px;}
.skel-hero{height:120px;width:100%;border-radius:var(--radius);}
.skel-card{height:160px;flex:1;min-width:200px;border-radius:var(--radius);}
.skel-card-sm{height:100px;flex:1;min-width:120px;border-radius:var(--radius);}

/* ══════════════════════════════════════
   MOBILE — OTIMIZAÇÃO COMPLETA
   Alvo: celular Android básico 360–480px
   no sol, com luva, sinal ruim
══════════════════════════════════════ */


/* ══════════════════════════════════════════════════════════
   CLS PREVENTION — Cumulative Layout Shift (Core Web Vitals)
   Todos os containers que recebem dados assíncronos têm
   min-height reservado para que a página não "pule" quando
   a API responder. Calculado pelo tamanho real do conteúdo.
══════════════════════════════════════════════════════════ */

/* ── Temperatura atual ── */
/* Ícone WMO (3.2rem) + temperatura (3.5rem) lado a lado */
.temp-main          { min-height: 5.5rem; }
.wi-icon-big        { min-height: 3.5rem; display: inline-flex; align-items: center; }
.temp-big           { min-height: 4rem;   display: inline-flex; align-items: center; }
.temp-desc          { min-height: 1.4rem; }
.temp-minmax        { min-height: 1.2rem; }

/* ── Cards de métricas (umidade, vento, chuva…) ── */
/* Cada .metric contém label + valor + unidade ≈ 3 linhas */
.metric             { min-height: 72px; }
.metric-val         { min-height: 1.6rem; }

/* ── Cotações — ticker marquee ── */
/* Altura da barra já fixada pelo padding do #cotacoes-bar;
   o ticker precisa de height para não colapsar no estado "Carregando" */
.cotacoes-ticker    { min-height: 22px; }
#cot-cidade-badge   { min-height: 20px; }

/* ── Barra de decisão do dia ──
   display:none → block empurra conteúdo; reservamos altura mínima
   do wrapper interno para o salto ser previsível e único */
.db-answer          { min-height: 2rem;  }
.db-sub             { min-height: 1.3rem; }
/* db-actions: entre 1 e 3 pills de ~2rem cada */
.db-actions         { min-height: 2.5rem; }

/* ── Micro-decisões ── */
/* Cada card tem ícone + tópico + decisão + detalhe + badge */
.md-card            { min-height: 140px; }
.md-decision        { min-height: 1.8rem; }
.md-detail          { min-height: 2.4rem; } /* ~2 linhas a 0.74rem */
.md-badge           { min-height: 1.4rem; }

/* ── Previsão 7 dias — carrossel ── */
/* Sem min-height no strip os cards colapsam antes dos dados */
.forecast-strip     { min-height: 130px; }
/* fc-day já tem min-height:44px (acessibilidade); reforça para conteúdo real */
.fc-day             { min-height: 110px; }
.fc-icon            { min-height: 1.8rem; display: flex; align-items: center; justify-content: center; }
.fc-temp            { min-height: 1.2rem; }

/* ── Previsão hora a hora ── */
.hourly-strip       { min-height: 82px; }
/* hr-item já tem min-height:44px (acessibilidade); reforça */
.hr-item            { min-height: 76px; }

/* ── Janela de Pulverização (card interno) ── */
#pulv-badge-wrap    { min-height: 2.2rem; }
/* grade de critérios: 2 linhas × 2 cols ≈ 90px */
.pulv-criteria      { min-height: 90px; }

/* ── Alertas — container recebe HTML dinâmico ── */
#alertas-container  { min-height: 80px; }

/* ── Status bar — textos preenchidos assincronamente ── */
.status-city        { min-height: 22px; }
.status-coords      { min-height: 1rem; }
.status-time        { min-height: 1rem; }

/* ── Histórico hídrico — gráficos carregam após fetch ── */
/* Canvas já tem height explícita no HTML (260px / 200px) — OK */
/* Apenas o cabeçalho de resumo precisa de reserva */
.hist-summary-row   { min-height: 90px; }
.hist-sum-val       { min-height: 1.8rem; }

/* ── Veranico — monitor exibido após render ──
   O wrapper interno já tem padding; garante que a altura
   não colapsa enquanto os dados não chegaram */
.veranico-content   { min-height: 72px; }
.veranico-titulo    { min-height: 1.5rem; }
.veranico-corpo     { min-height: 2.5rem; }

/* ── 680px: layout geral ── */
@media(max-width:680px){

  /* Topbar compacto */
  #topbar{font-size:.7rem;padding:.35rem .6rem;}
  .tb-right{gap:.5rem;}

  /* Header compacto mas visível — relógio NÃO some mais */
  header{padding:1rem 1rem .9rem;}
  .header-inner{gap:.75rem;flex-wrap:nowrap;align-items:center;}
  .logo-mark{width:42px;height:42px;flex-shrink:0;}
  .brand h1{font-size:1.25rem;}
  .brand p{display:none;} /* só o tagline some */
  /* Relógio: visível em mobile médio, some apenas em telas muito pequenas (360px) */
  .header-right{
    margin-left:auto;
    text-align:right;
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    gap:0;
  }
  #clock{font-size:1.1rem;}
  #date-label{font-size:.6rem;}
  #last-update{display:none;}

  /* Nav scroll horizontal */
  .nav-inner{flex-wrap:nowrap;overflow-x:auto;padding:.4rem .6rem;gap:.1rem;-webkit-overflow-scrolling:touch;}
  .nav-inner::-webkit-scrollbar{display:none;}
  nav a{font-size:.68rem;padding:.42rem .55rem;white-space:nowrap;}

  /* Main padding */
  main{padding:0 .6rem;margin-top:1rem;}
  section{margin-bottom:1.5rem;}

  /* Selector — coluna única */
  .selector-box{padding:.85rem .9rem;}
  .selector-row{flex-direction:column;gap:.6rem;}

  /* Autocomplete — toque fácil */
  .ac-wrap{min-width:0;width:100%;}
  #ac-input{
    font-size:1.05rem;
    padding:.85rem 2.4rem .85rem 2.6rem; /* alto o suficiente para dedo/luva */
    min-height:52px;
  }
  .ac-search-icon{font-size:1.1rem;left:.75rem;}
  .ac-clear{right:.7rem;font-size:1.1rem;min-width:32px;min-height:32px;}
  /* Dropdown no mobile: ocupa toda a largura e limita altura */
  #ac-dropdown{
    max-height:55vh; /* não ultrapassa metade da tela */
    border-radius:0 0 10px 10px;
    font-size:.95rem;
  }
  .ac-item{padding:.75rem 1rem;min-height:48px;} /* alvo de toque mínimo */
  .ac-group-label{font-size:.65rem;padding:.45rem 1rem .25rem;}

  /* Botão Buscar — 48px mínimo, largura cheia */
  #btn-buscar{
    width:100%;
    min-height:52px;
    font-size:1rem;
    padding:.85rem 1rem;
    justify-content:center;
    border-radius:8px;
  }

  /* Cards em coluna única */
  .weather-grid{grid-template-columns:1fr;}
  .card{padding:.9rem 1rem;}
  .card h3{font-size:.95rem;}

  /* Fontes maiores para leitura ao sol */
  body{font-size:16px;}
  .metric-val{font-size:1.4rem;}
  .metric-label{font-size:.72rem;}
  .metric{padding:.8rem .9rem;}
  .temp-big{font-size:3rem;}

  /* Status bar */
  .status-bar{padding:.5rem .75rem;gap:.45rem;flex-wrap:wrap;}
  .status-city{font-size:.9rem;}
  .status-coords{display:none;} /* coordenadas não cabem */
  .status-time{font-size:.7rem;}

  /* Forecast dias */
  .fc-day{min-width:76px;padding:.65rem .5rem;}
  .fc-icon{font-size:1.5rem;}
  .fc-temp{font-size:.95rem;}

  /* Calendário e dicas: coluna única */
  .tips-grid,.calendar-grid{grid-template-columns:1fr;}
  .cal-body,.tip-body{font-size:.82rem;}

  /* Mapa MT: esconde estatísticas laterais */
  .map-stats{display:none;}
  .map-banner{padding:1rem 1.1rem;}

  /* Veranico — layout vertical */
  .veranico-inner{flex-direction:column;gap:.6rem;}
  .veranico-icone{font-size:1.8rem;}
  .veranico-titulo{font-size:.9rem;}
  .veranico-corpo{font-size:.78rem;}


  /* Hero pulverização */
  .pulv-hero-inner{padding:1rem 1rem;flex-direction:column;align-items:flex-start;gap:.6rem;}
  .pulv-hero-metrics{margin-left:0;width:100%;justify-content:space-between;}
  .ph-metric{flex:1;min-width:0;}
  .pulv-hero-status{font-size:1.2rem;}

  /* Skeleton */
  .skel-card{min-width:120px;}

  /* IA */
  .ai-suggestions{flex-wrap:nowrap;overflow-x:auto;padding-bottom:.35rem;-webkit-overflow-scrolling:touch;}
  .ai-suggestions::-webkit-scrollbar{display:none;}
  .ai-sug{white-space:nowrap;font-size:.8rem;padding:.38rem .85rem;min-height:36px;}
  .ai-input-row{flex-direction:column;}
  #ai-question{font-size:1rem;padding:.8rem 1rem;min-height:48px;}
  #btn-ai{min-height:52px;font-size:1rem;padding:.8rem;}
  .ai-auto-grid{grid-template-columns:1fr;}

  /* Toast — fica acima do teclado */
  .gps-toast{bottom:5rem;font-size:.8rem;padding:.6rem 1.1rem;max-width:90vw;white-space:normal;text-align:center;}
}

/* ── 480px: telas muito pequenas ── */
@media(max-width:480px){
  .brand h1{font-size:1.1rem;}
  #clock{font-size:1rem;}
  .temp-big{font-size:2.7rem;}
  .pulv-hero-status{font-size:1.05rem;}
  .ph-metric{padding:.35rem .45rem;}
  .ph-metric-val{font-size:.95rem;}
  .ph-metric-lbl{font-size:.55rem;}
  nav a{font-size:.62rem;padding:.38rem .45rem;}
  .metric-val{font-size:1.25rem;}
  #ac-input{font-size:1rem;}
  #ac-dropdown{max-height:50vh;}
}

/* ── 360px: o Moto G mais básico do Brasil ── */
@media(max-width:360px){
  header{padding:.75rem .7rem;}
  .logo-mark{width:36px;height:36px;}
  .brand h1{font-size:1rem;}
  .header-right{display:none !important;} /* sem espaço — relógio some só aqui */
  main{padding:0 .45rem;}
  .card{padding:.75rem .8rem;}
  .metric-val{font-size:1.15rem;}
  .temp-big{font-size:2.4rem;}
  .fc-day{min-width:64px;}
  #btn-buscar{font-size:.92rem;}
}
