*{box-sizing:border-box}html,body{height:100%}
:root{
  --bg:#F8F9FC; --card:#FFFFFF; --surface:#FFFFFF; --text:#000000; --muted:#6B7280;
  --primary:#888ee0; /* Purple */
  --primary-contrast:#fff;
  --accent:#8FCBFF; /* Light Blue */
  --border:#cdced1;
}
.dark{
  --bg:#0B0B10; --card:#121219; --surface:#121219; --text:#F5F6FA; --muted:#A3A3B2;
  --primary:#8FCBFF; /* Light Blue for dark theme */
  --primary-contrast:#0B0B10;
  --accent:#888ee0;
  --border:#3c3c4b;
}
body{margin:0;background:var(--bg);color:var(--text);font:16px/1.5 system-ui,Segoe UI,Roboto,Inter,Arial}
/* container cresce com a tela, mas sem exagero */
:root{ --container-max: clamp(960px, 84vw, 1320px); }  /* 960 → 1320 */
.container{
  max-width: var(--container-max);
  margin: 0 auto;
  padding-inline: clamp(16px, 3vw, 32px);  /* padding lateral responsivo */
  padding-block: 16px;                      /* mantém altura */
}.header,.footer{display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.logo-circle{width:22px;height:22px;border-radius:50%;background:linear-gradient(180deg,#8FCBFF,#7A5FA7)}
.nav .chip{margin-left:6px}
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;margin:14px 0;box-shadow:0 6px 18px rgba(0,0,0,.05)}
h1{margin:8px 0 12px}
.muted{color:var(--muted)}
.link{color:var(--primary);text-decoration:none;margin-left:12px}
.link:hover{text-decoration:underline}
.timer{text-align:center;margin:16px 0}
.time{font-size:64px;font-weight: 700;font-size: 4rem;letter-spacing:1px;will-change: transform}
.controls{display:flex;gap:10px;justify-content:center;margin-top:12px}
.btn{padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer}
.btn:hover{border-color:var(--primary)}
.btn.primary{background:var(--primary);color:var(--primary-contrast);border-color:transparent}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field input,.field select{padding:10px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text)}
.stats{display:flex;gap:16px;justify-content:center;margin-top:12px}
.chip{border:1px solid var(--border);background:transparent;color:var(--text);padding:6px 10px;border-radius:999px;cursor:pointer}
.ad{display:block;text-align:center}
@media (max-width:640px){.grid{grid-template-columns:1fr} .time{font-size:48px}}

/* antes: .time.last-minute { ... } */
@keyframes timerPulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.08); }
}
#time.last-minute{
  animation: timerPulse 1s infinite;
  color: var(--thema);
}

/* antes: .ring-wrap .time { ... } */
.ring-wrap #time{
  position:absolute; inset:0; display:flex;
  align-items:center; justify-content:center;
}

.header {
  position: relative;
}
.brand img {
  height: 150px;
  position: absolute;
  top: 0px; /* sobe um pouco para não empurrar tudo */
}
.brand img {
  height: 150px; /* ou o valor que quiser */
  max-height: 100%;
  display: block;
}

.brand img:hover {
  filter: brightness(1.1); /* leve brilho ao passar o mouse */
}
/* General styles */
.brand span{display:none} /* Hide text when logo present */
.btn.primary:hover{filter:brightness(1.05)}
.header{border-bottom:1px solid var(--border)}
.footer{border-top:1px solid var(--border)}
.logo-circle{display:none} /* replaced by real logo */

.lang{position:relative}
.lang-toggle{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;border:1px solid var(--border);
  background:var(--text);color:var(--card); /* dark pill like screenshot */
  cursor:pointer; line-height:1;
}
.lang-toggle .globe{opacity:.9}
.lang-toggle .chev{margin-left:4px;opacity:.9}
.lang-menu{
  position:absolute; top:42px; left:0; min-width:160px;
  background:var(--card); color:var(--text); border:1px solid var(--border);
  border-radius:12px; box-shadow:0 10px 24px rgba(0,0,0,.12);
  padding:6px; list-style:none; margin:0; display:none; z-index:10;
}
.lang-menu.open{display:block}
.lang-menu li{
  padding:8px 10px; border-radius:8px; cursor:pointer;
}
.lang-menu li:hover{background:rgba(192, 186, 202, 0.12)} /* primary tint */

.lang-menu li{display:flex;align-items:center;gap:8px}

.lang-menu li{display:flex;align-items:center;gap:6px}

.lang-menu {
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.lang-menu:hover {
  box-shadow: 0 0 8px rgba(255, 255, 255, 0.4); /* brilho leve */
  transform: scale(1.0); /* leve aumento para dar destaque */
}

#toggle-theme{
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  border-radius:999px; border:1px solid var(--border);
  background:var(--card); color:var(--text); cursor:pointer;
  font-size:18px; line-height:1;
}
#toggle-theme:hover{background:var(--primary); color:var(--primary-contrast)}


/* --- Fix chip sizing & theme button --- */
.chip{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:36px; padding:6px 12px; border-radius:999px;
  border:1px solid var(--border); background:transparent; color:var(--text);
  font-weight:600;
}
#toggle-theme{ width:42px; padding:0; font-size:16px; line-height:1; }
#toggle-theme:hover{ border-color: var(--primary); }
.dark #toggle-theme{ color: var(--text); }

/* Language pill contrast in dark mode */
.dark .lang-toggle{ background:#1C1C26; color:#fff; border-color:var(--border); }
.dark .lang-menu{ background:#121219; color:var(--text); border-color:var(--border); }
.dark .lang-menu li:hover{ background:rgba(143,203,255,.12); }


/* Nav alignment: keep items side-by-side */
.nav{display:flex; align-items:center; gap:10px}

/* Ensure elements inside nav don't wrap oddly */
.nav > * { display:inline-flex; align-items:center }

/* Language combo pill alignment */
.lang{ position:relative; display:inline-flex }
.lang-toggle{ line-height:1; height:36px }

/* Theme button: consistent size and alignment */
#toggle-theme{
  height:36px; width:36px; padding:0; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
}

/* Dropdown stacking & visibility */
.lang-menu{ z-index:1000; overflow:hidden }
.header{ overflow:visible } /* make sure dropdown isn't clipped */

/* Progress ring */
.ring-wrap{ position:relative; display:inline-block; }
.ring{
  --p: 0deg;
  width: 220px; height: 220px; border-radius: 50%;
  background: conic-gradient(var(--primary) var(--p), rgba(46, 46, 46, 0.08) 0);
  display:block;
}
.dark .ring{ background: conic-gradient(var(--accent) var(--p), rgba(255,255,255,0.1) 0); }
.ring-wrap .time{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }

/* Grids */
.grid.small{ grid-template-columns: repeat(3, 1fr); }
.preset-row{ display:flex; gap:8px; margin-top:6px; }

/* Options row */
.options-row{ display:flex; align-items:center; gap:10px; margin-top:10px; }

/* Switch */
.switch{ position:relative; width:44px; height:24px; }
.switch input{ display:none; }
.switch span{
  position:absolute; inset:0; border-radius:999px; background:#d1d5db; border:1px solid var(--border);
}
.switch span::after{
  content:''; position:absolute; top:2px; left:2px; width:18px; height:18px;
  background:#fff; border-radius:50%; transition:transform .2s ease;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.switch input:checked + span{ background:var(--primary); }
.switch input:checked + span::after{ transform: translateX(20px); }
.dark .switch span{ background:#2a2a36; }

/* Keyboard focus styles */
.chip:focus-visible, .lang-toggle:focus-visible, .lang-menu li:focus-visible,
#start:focus-visible, #pause:focus-visible, #reset:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-color: var(--accent);
}
.lang-menu li { outline: none; }

/* Pulse feedback */
@keyframes pulse { from { box-shadow:0 0 0 rgba(0,0,0,0)} to { box-shadow:0 0 18px rgba(122,95,167,.25)} }
.card.pulse { animation:pulse .4s ease; }

/* Mobile adjustments */
@media (max-width:420px){
  .grid, .grid.small { grid-template-columns:1fr; }
  .preset-row { flex-wrap: wrap; }
}


/* Keyboard focus styles */
.chip:focus-visible, .lang-toggle:focus-visible, .lang-menu li:focus-visible,
#start:focus-visible, #pause:focus-visible, #reset:focus-visible, #notify-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-color: var(--accent);
}

/* Pulse feedback */
@keyframes fz-pulse { from { box-shadow:0 0 0 rgba(0,0,0,0) } to { box-shadow:0 0 18px rgba(122,95,167,.25) } }
.card.pulse { animation:fz-pulse .4s ease; }

/* Ring transition for smoother updates */
.ring { transition: background .3s linear; }

/* Mobile tweaks */
@media (max-width: 420px){
  .grid, .grid.small { grid-template-columns: 1fr; }
  .preset-row { flex-wrap: wrap; }
}


#reset-sessions {
  margin-left: 0.5rem;
  background-color: var(--accent);
  color: white;
}
#reset-sessions:hover {
  background-color: var(--accent-hover, #4a3f78);
}


/* Modal */
.modal.hidden{ display:none }
.modal{
  position:fixed; inset:0; background:rgba(0,0,0,.35);
  display:flex; align-items:center; justify-content:center; z-index:2000;
}
.modal-card{
  background:var(--card); color:var(--text);
  border:1px solid var(--border); border-radius:14px;
  padding:20px; width:min(420px, 92vw); box-shadow:0 12px 40px rgba(0,0,0,.2);
}
.modal-actions{ display:flex; gap:10px; justify-content:flex-end; margin-top:16px }

/* Toast */
.toast
{
  position: fixed;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  background: var(--toast-bg, #3B3F56);
  color: #fff;
  padding: 10px 14px;
  border-radius: 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,.15);
  font-size: 14px;
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  transition: opacity .2s ease;
}
.toast.show{ opacity:1; transform:translateX(-50%) translateY(-4px) }


/* Modal animations */
@keyframes modalFadeIn {
  from { opacity:0; transform:scale(0.96); }
  to { opacity:1; transform:scale(1); }
}
@keyframes modalFadeOut {
  from { opacity:1; transform:scale(1); }
  to { opacity:0; transform:scale(0.96); }
}
.modal.show .modal-card {
  animation: modalFadeIn 0.18s ease-out forwards;
}
.modal.hiding .modal-card {
  animation: modalFadeOut 0.15s ease-in forwards;
}

/* Reset sessions chip */

.reset-chip:hover{ border-color: var(--primary); }

/* Break-mode color (Lilás Pastel) for the progress ring */
.ring.is-break{
  background: conic-gradient(#A89DF5 var(--p), rgba(0,0,0,0.08) 0);
}
.dark .ring.is-break{
  background: conic-gradient(#A89DF5 var(--p), rgba(255,255,255,0.1) 0);
}


/* AdSense slots */
.ad-slot{margin:12px 0}
.ad-top,.ad-middle{min-height:90px}
.ad-inline{min-height:250px}
@media(max-width:480px){.ad-inline{min-height:180px}}

/* Consent banner */
.consent{position:fixed;left:12px;right:12px;bottom:12px;background:var(--card);color:var(--text);
  border:1px solid var(--border);padding:10px;border-radius:10px;z-index:3000;
  box-shadow:0 10px 24px rgba(0,0,0,.2)}
.consent.hidden{display:none}

/* faz o cartão principal ocupar toda a largura do container */
main .card{
  max-width: 100%;
  margin-inline: 0;
  padding-inline: clamp(16px, 2.5vw, 32px);
}

/* se usar grid, garanta que o cartão não fique preso a poucas colunas */
.grid > .card{ grid-column: 1 / -1; }

@media (min-width: 1536px){
  :root{ --container-max: 1400px; }
}

.footer a:hover {
  color: var(--primary-hover);
  text-decoration: underline;
}

.footer a,
.footer a:visited,
.footer a:active {
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}


.ad-slot.ad-bottom {
  min-height: 0; /* garante que não reserva espaço */
  display: none; /* escondido por padrão */
}

.ad-slot.ad-bottom.is-filled {
  display: block; /* só aparece quando tiver anúncio */
  margin-top: 1rem; /* ou o espaçamento que quiser */
}


/* Ad slots: não deixar espaço quando ainda não estiver preenchido */
.ad-slot { display: block; }
.ad-slot .adsbygoogle { display: block; min-height: 0 !important; }

/* Enquanto não preencher, não ocupa espaço */
.ad-slot:not(.is-filled) {
  height: 0;
  margin: 0;
  overflow: hidden;
}

/* Quando preencher, libera a margem normalmente */
.ad-slot.is-filled { margin: 12px 0; }

/* ===== Consent Banner – layout e tema ===== */
#consent-banner.consent{
  z-index: 2147483647;
  position: fixed;
  left: 0; right: 0; bottom: 0;
  background: var(--card);
  color: var(--text);
  border-top: 1px solid var(--border);
  padding: 12px 16px;
  display: flex;
  flex-wrap: wrap;              /* permite quebrar texto/btns */
  align-items: center;
  justify-content: center;      /* centraliza o conjunto */
  gap: 12px;
  box-shadow: 0 -2px 8px rgba(0,0,0,.08);
}

/* Texto centralizado e com largura confortável */
#consent-banner.consent > span{
  flex: 1 1 700px;              /* cresce, mas limita a quebra */
  text-align: center;
  line-height: 1.45;
}

/* Botões sempre centralizados; em telas pequenas ocupam a linha de baixo */
#consent-banner .consent-buttons{
  display: flex;
  gap: 8px;
  justify-content: center;
  width: 100%;
}

/* Em telas médias+, mantemos tudo na mesma linha quando couber */
@media (min-width: 768px){
  #consent-banner .consent-buttons{ width: auto; }
}

/* Link no padrão do site */
#consent-banner a{
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}
#consent-banner a:hover{
  filter: brightness(1.1);      /* leve brilho no hover */
}

/* Ajuste visual dos chips dentro do banner */
#consent-banner .chip{
  height: 36px;
  padding-inline: 14px;
  border-radius: 9999px;
}
/* Botão Aceitar no padrão do tema */
#consent-banner .chip.primary{
  background: var(--primary);
  color: #000000;
  font-weight: 600;
}
#consent-banner .chip.primary:hover{
  filter: brightness(1.09);
}

/* FIX: consent sempre no topo e clicável */
#consent-banner.consent {
  z-index: 2147483647;  /* acima de qualquer overlay/ad */
  pointer-events: auto;
}

/* FIX: ad-slot vazio não captura clique */
.ad-slot:not(.is-filled),
.ad-slot:not(.is-filled) .adsbygoogle {
  pointer-events: none;
}

/* FIX: se algum ad-slot tiver z-index alto, neutraliza */
.ad-slot { z-index: auto !important; }

/* Garante que "hidden" realmente esconda o banner, mesmo com a regra do ID */
#consent-banner.consent.hidden {
  display: none !important;
}

/* === Sound select estilizado no tema claro === */
#sound {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  height: 36px;
  line-height: 36px;
  padding: 0 42px 0 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--text);   /* no escuro isso fica pill */
  color: var(--card);
  cursor: pointer;
  transition: border-color .15s ease, filter .15s ease;
}

/* Tema escuro: pill dark */
.dark #sound {
  background: #1C1C26;
  color: #fff;
  border-color: var(--border);
  background-image: url('data:image/svg+xml;utf8,\
<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 24 24">\
<path fill="%23FFFFFF" d="M7 10l5 5 5-5z"/></svg>');
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 14px;
}

/* Tema claro: pill claro */
:root:not(.dark) #sound {
  background: #fff;
  color: #333;
  border-color: #ccc;
  background-image: url('data:image/svg+xml;utf8,\
<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 24 24">\
<path fill="%233B3F56" d="M7 10l5 5 5-5z"/></svg>');
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 14px;
}

/* Hover/focus */
#sound:hover { border-color: var(--primary); filter: brightness(1.03); }
#sound:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-color: var(--accent);
}

/* Container dos botões */
#button-container {
  display: flex;
  justify-content: space-between; /* um à esquerda e outro à direita */
  align-items: center;
  margin-top: 10px;
}

/* botão reset */
#reset-stats {
  height: 36px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  transition: filter .2s ease, background .2s ease;
}
#reset-stats:hover {
  filter: brightness(1.06);
  border-color: var(--primary);
}
.dark #reset-stats:hover {
  background: var(--primary);
  color: #fff;
}

/* botão test sound */
#sound-test {
  height: 36px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  transition: filter .2s ease, background .2s ease;
}
#sound-test:hover {
  filter: brightness(1.06);
  border-color: var(--primary);
}
.dark #sound-test:hover {
  background: var(--primary);
  color: #fff;
}

/* === Sound toggle (isolated) === */
#sound-label{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  width:100%;
  min-width:0;
}
.sound-toggle{
  appearance:none;
  background:none;
  border:none;
  padding:0;
  width:28px; height:28px;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:16px; line-height:1;
  color:var(--text);
  border:1px solid var(--border);
  border-radius:6px;
  cursor:pointer;
  transition:transform .15s ease, opacity .15s ease;
}
.sound-toggle:hover{ transform:scale(1.05); }
.sound-toggle[aria-pressed="false"]{ opacity:.6; }

/* linha do título com botão à direita */
.title-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  margin-bottom:.5rem;             /* respiro antes do subtítulo */
}
.title-bar h1{
  margin:0;                        /* tira margem padrão do h1 */
  line-height:1.15;                /* deixa mais “encaixado” */
}

/* botão de interrogação, discreto e consistente com o tema */
.icon-btn{
  inline-size:28px;                /* largura */
  block-size:28px;                 /* altura */
  border-radius:9999px;            /* totalmente circular */
  border:1px solid var(--border);
  background:var(--surface);       /* usa o mesmo tom do card */
  color:var(--text);
  display:inline-grid; place-items:center;
  font-weight:700; font-size:.95rem;
  opacity:.75;
  cursor:pointer;
  transition:opacity .2s, transform .12s ease;
}
.icon-btn:hover{ opacity:1; transform:translateY(-1px); }
.icon-btn:focus{ outline:2px solid var(--accent); outline-offset:2px; }


/* Fallback rápido caso seu projeto não tenha estilos de modal */
.modal{ position:fixed; inset:0; display:grid; place-items:center; background:rgba(0,0,0,.45); z-index:50; }
.modal.hidden{ display:none; }
.modal-card{ width:min(520px, 92vw); background:var(--surface); border:1px solid var(--border);
  border-radius:12px; padding:16px 16px 12px; box-shadow:0 10px 30px rgba(0,0,0,.35); }

/* Keycaps e lista */
.kbd{ display:inline-block; padding:2px 6px; border:1px solid var(--border); border-radius:6px;
  font: 400 .85em ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  background:var(--bg); color:var(--text); line-height:1.2; }
.shortcut-list{ list-style:none; padding:0; margin:.5rem 0 1rem; display:grid; gap:.45rem; }
.shortcut-list li{ display:flex; align-items:center; gap:.5rem; }
.modal-actions{ display:flex; justify-content:flex-end; gap:.5rem; }

/* ——— Modal mais legível ——— */

/* Fundo mais escuro (menos transparência) */
.modal{
  background: rgba(0,0,0,.65);   /* antes .45 */
  backdrop-filter: none;         /* evita blur se existir */
  z-index: 50;
}

/* Card opaco, com contraste melhor */
.modal-card{
  background: var(--surface);    /* sólido, sem transparência */
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 16px 12px;
  box-shadow: 0 14px 40px rgba(0,0,0,.55); /* sombra um pouco mais forte */
}

/* (opcional) reforça contraste do título e conteúdo */
.modal-card h3{ color: var(--text); }
.shortcut-list{ color: var(--text); }


/* Fundo mais escuro (overlay do modal) */
.modal {
  background: rgba(0,0,0,.65); /* overlay por trás */
}

/* Card com fundo sólido para leitura melhor */
.modal-card {
  background: #ffffff;   /* fundo branco no tema claro */
  color: #020202;           /* texto escuro */
}

.dark .modal-card {
  background: #0d001b;   /* fundo sólido no tema escuro */
  color: #f5f5f5;        /* texto claro */
}


/* ===== Acessibilidade util ===== */
.sr-only{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); border:0;
}

/* ===== Container principal do módulo ===== */
.tasks-card{
  margin-top:18px;
  border:1px solid var(--border, rgba(255,255,255,.12));
  background:var(--surface, #121216);
  border-radius:14px;
  padding:16px;
}

/* ===== Título + entrada ===== */
.tasks-titlebar{ display:grid; gap:.65rem; }
.tasks-h2{ margin:0; font-size:1.5rem; font-weight:800; letter-spacing:.1px; }

.tasks-input-row{
  display:flex; gap:.5rem; align-items:center; flex-wrap:wrap;
}
.tasks-input {
  flex: 1 1 280px;
  min-width: 240px;
  height: 42px;
  border: 1px solid var(--border, rgba(255,255,255,.12));
  background: transparent;
  border-radius: 10px;
  padding: 0 .8rem;
  font-family: Inter, sans-serif;
}

/* Tema claro */
[data-theme="light"] .tasks-input {
  color: #3B3F56; /* texto principal */
  border-color: rgba(59, 63, 86, .25);
}
[data-theme="light"] .tasks-input::placeholder {
  color: rgba(59, 63, 86, .55);
}

/* Tema escuro */
[data-theme="dark"] .tasks-input {
  color: #f0f0f2;
  border-color: rgba(255,255,255,.12);
}
[data-theme="dark"] .tasks-input::placeholder {
  color: rgba(255,255,255,.55);
}


.tasks-btn {
  height: 42px;
  padding: 0 .95rem;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  transition: background 0.2s ease, transform 0.1s ease;
}

/* Tema claro */
[data-theme="light"] .tasks-btn {
  background: #888ee0; /* fundo claro */
  color: #f2f2f5;      /* texto de apoio */
  border: 1px solid rgba(14, 15, 20, 0.25);
}

/* Tema escuro */
[data-theme="dark"] .tasks-btn {
  background: #8FCBFF; /* fundo escuro */
  color: #000000;
  border: 1px solid rgba(255,255,255,.12);
}

/* Botão primário */
.tasks-btn--primary {
  background: #7A5FA7; /* primária (Start) */
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 0 .95rem;
  font-weight: 600;
  cursor: pointer;
  height: 42px;
  transition: background 0.2s ease, transform 0.1s ease;
}

/* Active primário */
.tasks-btn--primary:active {
  transform: translateY(-4px);
}


/* base */
.tasks-note {
  margin: .1rem 0 0;
  font-size: .88rem;
  font-family: Inter, sans-serif;
}

/* tema claro */
[data-theme="light"] .tasks-note {
  color: rgba(59, 63, 86, 0.75); /* apoio (#3B3F56) suavizado */
}

/* tema escuro */
[data-theme="dark"] .tasks-note {
  color: rgba(255, 255, 255, 0.75);
}

.tasks-note-muted{ opacity:.8; }

/* ===== Colunas ===== */
.tasks-columns{
  display:grid; gap:14px; margin-top:.25rem;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 780px){
  .tasks-columns{ grid-template-columns: 1fr; }
}

.tasks-col{
  border:1px solid var(--border, rgba(255,255,255,.12));
  background:var(--surface, #121216);
  border-radius:12px; padding:12px;
}

/* Cabeçalho de coluna com hierarquia mais forte */
.tasks-col-head{
  display:flex; align-items:center; justify-content:space-between; gap:.75rem;
  border-radius:10px; padding:8px 10px; color:#fff; margin-bottom:.6rem;
  font-weight:800;
}
.tasks-col[data-col="todo"] .tasks-col-head{ background:#2563eb; }  /* azul mais sóbrio */
.tasks-col[data-col="done"] .tasks-col-head{ background:#10b981; }  /* verde */
.tasks-h3{ margin:0; font-size:1rem; }
.tasks-badge{
  background:rgba(0,0,0,.18); padding:3px 10px; border-radius:999px; font-weight:800;
}

/* Lista e estados */
.tasks-list{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:10px;
  min-height:48px;
}
.tasks-empty{
  border:1px dashed var(--border, rgba(255,255,255,.18));
  color:rgba(255,255,255,.7);
  border-radius:10px; padding:.8rem; text-align:center;
}

/* Card de tarefa com contraste/respiro melhores */
.tasks-item{
  border:1px solid rgba(8, 8, 8, 0.822);
  background:var(--bg, #0d0f14);
  color:var(--text);                /* contraste mais alto */
  border-radius:12px;
  padding:12px;
  display:flex; flex-direction:column; gap:8px;
  box-shadow: 0 0 0 0 rgba(0,0,0,0);
  transition: box-shadow .15s ease, transform .08s ease, border-color .15s ease;
}
.tasks-item:hover{
  box-shadow: 0 10px 22px rgba(0,0,0,.25);
  border-color: rgba(255,255,255,.18);
}
.tasks-item--done .tasks-body{  text-decoration: line-through; }

.tasks-body{
  word-break: break-word; line-height: 1.42; font-size:.98rem;
}

/* Ações: lixeira aparece só no hover/foco */
.tasks-actions{
  display:flex; justify-content:flex-end; gap:.4rem;
}
.tasks-icon-btn{
  inline-size:30px; block-size:30px; display:grid; place-items:center;
  border:1px solid var(--border, rgba(255,255,255,.16));
  border-radius:9px; background:var(--surface, #121216);
  color:var(--text, #eaeaf0); cursor:pointer; opacity:.0;  /* escondido por padrão */
  transform: translateY(2px);
  transition: opacity .12s ease, transform .12s ease, background .12s ease;
}
.tasks-item:hover .tasks-icon-btn,
.tasks-item:focus-within .tasks-icon-btn{
  opacity:1; transform: translateY(0);
}
.tasks-icon-btn:hover{ background:rgba(255,255,255,.06); }
.tasks-icon-btn--danger{ color:#f87171; border-color: rgba(248,113,113,.35); }

/* micro-feedback de entrada (pronto para usar via JS) */
@keyframes tasks-enter {
  from { opacity:0; transform: translateY(6px); }
  to   { opacity:1; transform: translateY(0); }
}
.tasks-item--enter {
  animation: taskEnter 0.3s ease-out;
}

@keyframes taskEnter {
  from {
    opacity: 0;
    transform: translateY(-5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.tasks-item.completed {
  opacity: 0.6;
  transform: scale(0.98);
  transition: all 0.2s ease;
}


/* ===== Botões: base + variantes ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem;
  height:40px; padding:0 .95rem;
  border-radius:12px;
  font:600 0.95rem/1 Inter, system-ui, sans-serif;
  letter-spacing:.2px;
  border:1px solid transparent;
  background: var(--btn-bg, #1f2230);
  color: var(--btn-fg, #e8eaf2);
  transition: transform .06s ease, background .15s ease, border-color .15s ease, color .15s ease, box-shadow .15s ease;
  cursor:pointer;
}
.btn:active{ transform: translateY(1px); }
.btn:disabled{ opacity:.6; cursor:not-allowed; }

/* Primário: Iniciar/Retomar */
.btn--primary{
  background: var(--btn-primary-bg, var(--primary, #7A5FA7));
  color: var(--btn-primary-fg, #fff);
  box-shadow: 0 2px 12px rgba(0,0,0,.25);
}
.btn--primary:hover{ filter: brightness(1.06); }
.btn--primary:focus-visible{
  outline:none;
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--btn-primary-bg, #7A5FA7) 35%, #ffffff 0%);
}

/* Neutro: Pausar */
.btn--neutral{
  background: var(--btn-neutral-bg, color-mix(in oklab, #000 80%, #fff 20%)); /* cinza escuro */
  color: var(--btn-neutral-fg, #e5e7ef);
  border-color: color-mix(in oklab, #fff 10%, #000 90%);
}
.btn--neutral:hover{
  background: color-mix(in oklab, var(--btn-neutral-bg, #272a38) 90%, #fff 10%);
}

/* Outline: Reiniciar */
.btn--outline{
  background: transparent;
  color: var(--btn-outline-fg, #e5e7ef);
  border-color: var(--btn-outline-border, color-mix(in oklab, #fff 16%, #000 84%));
}
.btn--outline:hover{
  background: color-mix(in oklab, #fff 8%, transparent);
}

/* Acessibilidade */
@media (prefers-reduced-motion: reduce){
  .btn{ transition:none }
}
.btn:focus-visible{
  outline:none;
  box-shadow: 0 0 0 3px color-mix(in oklab, #8FCBFF 35%, transparent);
}

.meta-stats{display:flex;gap:.5rem;margin-top:.5rem}
.badge{padding:.25rem .6rem;border-radius:9999px;font:600 .85rem/1 Inter;background:color-mix(in oklab,#fff 8%,transparent);color:#e9ecf5;border:1px solid color-mix(in oklab,#fff 12%,#000 88%)}

/* =========================
   Chips inline — Option 1 (brand tint)
   ========================= */
.meta-chips{
  display:flex; flex-wrap:wrap; gap:.6rem;
  align-items:center; justify-content:center;
  margin: .75rem 0 0;
}

.chips--brand .chip{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.50rem .75rem;
  border-radius:9999px;
  background: var(--chip-brand-tint);       /* leve “tint” da marca */
  border: 1px solid var(--chip-border);
  color: var(--ink);
  font: 600 .92rem/1.1 Inter, system-ui, sans-serif;
  white-space: nowrap;
}

.chip__icon{
  display:inline-grid; place-items:center;
  width:22px; height:22px; border-radius:9999px;
  background: var(--chip-icon-sessions);
  color: #fff; font: 700 .85rem/1 Inter; letter-spacing:.2px;
}

/* Ícone verde só para o chip "Completed" */
.chip:nth-child(2) .chip__icon{ background: var(--chip-icon-completed); }

.chip__label{ color: var(--muted); font-weight:600; }
.chip__value{ color: var(--ink); font-weight:800; font-variant-numeric: tabular-nums; }

.chip:hover{
  filter: brightness(1.05);
  border-color: color-mix(in oklab, var(--chip-border) 60%, var(--primary) 40%);
}

.chip:focus-within{
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 35%, transparent);
  border-color: color-mix(in oklab, var(--primary) 55%, var(--chip-border));
}

@media (max-width: 560px){
  .meta-chips{ justify-content:space-between; }
  .chip{ flex:1 1 auto; justify-content:space-between; }
}

/* opcional: deixa o conjunto “abaixo do relógio” com um respiro maior */
.timer + .meta-chips{ margin-top: 1rem; }

/* ==== FIX LOGO MOBILE (mínimo) ==== */
:root { --logo-h: 60px; }               /* segue o guia: uso mínimo ≈32px */
@media (max-width: 420px) {
  :root { --logo-h: 28px; }             /* um passo menor em telas muito estreitas */
}

.header .brand,
.site-header .brand,
.navbar .brand { 
  flex-shrink: 0;                        /* não deixe o logo encolher por causa dos controles */
  min-width: 0;
}

.header .brand .logo-img,
.site-header .brand .logo-img,
.navbar .brand .logo-img {
  display: block;
  height: var(--logo-h);                 /* controla pela altura */
  width: auto !important;                /* mantém proporção do arquivo */
  max-width: min(56vw, 200px);           /* limita largura em telas pequenas */
  object-fit: contain;                   /* nunca estique */
  image-rendering: auto;                 /* nitidez em diferentes DPIs */
}

/* Opcional: aperta um pouco o espaço dos controles no mobile para sobrar área para o logo */
@media (max-width: 420px) {
  .header .toolbar, .site-header .toolbar, .navbar .toolbar { gap: 8px; }
  .lang-select { max-width: 44vw; }      /* evita que o seletor de idioma empurre o logo */
}

.how-steps { margin: .75rem 0 1rem; padding-left: 1.25rem; }
.how-steps li + li { margin-top: .25rem; }
.tips { margin-top: .75rem; }
#about-pomodoro ul { margin: .5rem 0 1rem; padding-left: 1.25rem; }
#how-to-use h2, #about-pomodoro h2 { margin-bottom: .5rem; }
#how-to-use h3, #about-pomodoro h3 { margin-top: .75rem; margin-bottom: .25rem; }

/* --- SECTIONS (How to use / Pomodoro Philosophy) --- */
.section-info {
  max-width: 800px;         /* igual ao bloco de tarefas/relogio */
  margin: 2rem auto;        /* centralizado */
  padding: 2rem;
  background: var(--bg-panel, #1e1e1e); /* segue painel dark */
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.section-info h2 {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  margin-bottom: 1rem;
  color: var(--text-title, #fff);
}

.section-info p,
.section-info li {
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--text-body, #ddd);
}

.section-info ul {
  margin: 1rem 0 0 1.5rem;
  list-style: disc;
}

/* tipografia de prosa: leitura confortável em dark */
.prose{
  line-height: 1.65;
  font-size: clamp(0.95rem, 0.28vw + 0.9rem, 1.05rem);
  color: var(--text, #e7e7e7);
}

.prose h2{
  font-weight: 600;
  font-size: clamp(1.25rem, 0.8vw + 1.1rem, 1.6rem);
  margin: 0 0 .6rem;
  color: var(--text, #fff);
}

.prose h3{
  font-weight: 600;
  font-size: clamp(1.05rem, 0.45vw + 1rem, 1.25rem);
  margin: 1rem 0 .4rem;
}

.prose p{ margin: 0 0 .75rem; }

/* listas com ritmo e alinhamento previsível */
.prose ol, .prose ul{
  margin: .5rem 0 1rem;
  padding-left: 1.25rem;
}
.prose li + li{ margin-top: .35rem; }
.prose strong{ color: var(--text, #fff); }

/* “caixa de dicas” (se usada nas sections) */
.prose .tips{
  background: var(--surface, #161616);
  border: 1px solid var(--border, #2a2a2a);
  padding: .75rem 1rem;
  border-radius: 12px;
}

/* separação visual do board de tasks */
#tasks-mvp{ margin-bottom: 12px; }          /* evita “grudar” nos artigos */

/* âncoras suaves caso use links #how-to-use / #about-pomodoro */
#how-to-use, #about-pomodoro{ scroll-margin-top: 80px; }

/* mobile: não deixar colar nas bordas */
@media (max-width: 480px){
  .card.article{ margin: 16px auto; padding: 16px; }
}
