@import "https://cdn.jsdelivr.net/npm/bulma@1.0.4/css/bulma.min.css"; @import "https://cdn.jsdelivr.net/npm/quill@2.0.3/dist/quill.snow.css"; :root, [data-tema="claro"] { --cor-primaria: #24211a; --cor-secundaria: #fa7785; --cor-harmonia-1: #d5d87d; --cor-harmonia-2: #b1d4b6; --cor-harmonia-3: #53cbbf; --cor-primaria-rgb: 36, 33, 26; --cor-secundaria-rgb: 250, 119, 133; --cor-fundo: #faf9f6; --cor-fundo-card: #ffffff; --cor-texto: #24211a; --cor-texto-suave: #5a574e; --sombra-card: 0 2px 12px rgba(36, 33, 26, 0.08); --sombra-card-hover: 0 6px 24px rgba(36, 33, 26, 0.14); --raio-borda: 12px; --transicao: all 0.25s cubic-bezier(0.4, 0, 0.2, 1); --cor-borda: rgba(36, 33, 26, 0.1); --cor-input-bg: #ffffff; --cor-input-borda: rgba(36, 33, 26, 0.2); --cor-editor-bg: #ffffff; --cor-editor-toolbar: #f5f5f5; --cor-editor-texto: #24211a; --cor-modal-body: #ffffff; --cor-modal-foot: #faf9f6; --cor-tabela-linha: #ffffff; --cor-tabela-linha-hover: color-mix( in srgb, var(--cor-harmonia-3) 8%, white ); --cor-tabela-borda: rgba(36, 33, 26, 0.06); --bulma-primary: var(--cor-primaria); --bulma-primary-h: 42; --bulma-primary-s: 16%; --bulma-primary-l: 12%; --bulma-link: var(--cor-secundaria); --bulma-link-h: 354; --bulma-link-s: 93%; --bulma-link-l: 72%; --bulma-info: var(--cor-harmonia-3); --bulma-success: var(--cor-harmonia-2); --bulma-warning: var(--cor-harmonia-1); --bulma-danger: var(--cor-secundaria); } [data-tema="escuro"] { --cor-fundo: #111111; --cor-fundo-card: #1e1e1e; --cor-texto: #e4e4e4; --cor-texto-suave: #9a9a9a; --sombra-card: 0 2px 12px rgba(0, 0, 0, 0.4); --sombra-card-hover: 0 6px 24px rgba(0, 0, 0, 0.55); --cor-borda: rgba(255, 255, 255, 0.08); --cor-input-bg: #2a2a2a; --cor-input-borda: rgba(255, 255, 255, 0.18); --cor-editor-bg: #2a2a2a; --cor-editor-toolbar: #242424; --cor-editor-texto: #e4e4e4; --cor-modal-body: #1e1e1e; --cor-modal-foot: #181818; --cor-tabela-linha: #1e1e1e; --cor-tabela-linha-hover: rgba(255, 255, 255, 0.04); --cor-tabela-borda: rgba(255, 255, 255, 0.06); } * { box-sizing: border-box; } html { scroll-behavior: smooth; } .modal-background { backdrop-filter: blur(10px); } body { font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; background-color: var(--cor-fundo); color: var(--cor-texto); min-height: 100vh; min-height: 100dvh; display: flex; flex-direction: column; } .conteudo-principal { flex: 1; display: flex; flex-direction: column; } .title { color: var(--cor-texto) !important; } .subtitle, .has-text-grey { color: var(--cor-texto-suave) !important; } .navbar-temptask { background: var(--cor-primaria); box-shadow: 0 2px 16px rgba(36, 33, 26, 0.18); position: sticky; top: 0; z-index: 30; border-bottom: 1px solid var(--cor-borda); } .navbar-temptask .navbar-item, .navbar-temptask .navbar-burger { color: #fff; } .navbar-temptask .navbar-item:hover { background: rgba(255, 255, 255, 0.08); color: var(--cor-harmonia-3); } .logo-temptask { font-weight: 800; font-size: 1.35rem; letter-spacing: -0.5px; color: #fff !important; } .logo-temptask .logo-icon { color: var(--cor-secundaria); } .hero-temptask { background: linear-gradient(135deg, var(--cor-primaria) 0%, #3a362b 100%); position: relative; overflow: hidden; } .hero-temptask::before { content: ""; position: absolute; top: -50%; right: -30%; width: 80%; height: 200%; background: radial-gradient( ellipse, rgba(83, 203, 191, 0.12) 0%, transparent 70% ); pointer-events: none; } .hero-temptask .title { color: #fff; font-weight: 800; letter-spacing: -1px; } .hero-temptask .subtitle { color: rgba(255, 255, 255, 0.8); } .destaque-secundaria { color: var(--cor-secundaria); } .destaque-harmonia { color: var(--cor-harmonia-3); } .card-temptask { background: var(--cor-fundo-card); border-radius: var(--raio-borda); box-shadow: var(--sombra-card); transition: var(--transicao); border: 1px solid var(--cor-borda); overflow: hidden; } .card-temptask:hover { box-shadow: var(--sombra-card-hover); transform: translateY(-2px); } .botao-primario { background: var(--cor-primaria) !important; color: #fff !important; border: none !important; border-radius: 8px !important; font-weight: 600 !important; transition: var(--transicao) !important; } .botao-primario:hover { background: #3a362b !important; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(36, 33, 26, 0.25); } .botao-secundario { background: var(--cor-secundaria) !important; color: #fff !important; border: none !important; border-radius: 8px !important; font-weight: 600 !important; transition: var(--transicao) !important; } .botao-secundario:hover { background: #f85c6d !important; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(250, 119, 133, 0.35); } .botao-harmonia { background: var(--cor-harmonia-3) !important; color: var(--cor-primaria) !important; border: none !important; border-radius: 8px !important; font-weight: 600 !important; transition: var(--transicao) !important; } .botao-harmonia:hover { background: #3fbfb3 !important; transform: translateY(-1px); } .tag-pendente { background: rgba(83, 203, 191, 0.15) !important; color: #2a9d8f !important; font-weight: 600; } .tag-concluida { background: rgba(177, 212, 182, 0.25) !important; color: #4a7c59 !important; font-weight: 600; } .tag-expirada { background: rgba(250, 119, 133, 0.15) !important; color: var(--cor-secundaria) !important; font-weight: 600; } .tag-timer { background: rgba(213, 216, 125, 0.2) !important; color: #8a8c3a !important; font-weight: 700; font-variant-numeric: tabular-nums; font-family: "JetBrains Mono", monospace; min-width: 90px; justify-content: center; } .tabela-listas { border-radius: var(--raio-borda); overflow: hidden; box-shadow: var(--sombra-card); border-collapse: separate; border-spacing: 0; } .tabela-listas thead th { background: var(--cor-primaria) !important; color: #fff !important; font-weight: 600; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.5px; border: none !important; padding: 0.9rem 1rem; } .tabela-listas tbody { border: none !important; } .tabela-listas tbody td { vertical-align: middle; border-color: var(--cor-tabela-borda) !important; border-bottom: 1px solid var(--cor-tabela-borda) !important; border-left: none !important; border-right: none !important; border-top: none !important; padding: 0.85rem 1rem; background-color: var(--cor-tabela-linha); color: var(--cor-texto); } .tabela-listas tbody tr:last-child td { border-bottom: none !important; } .tabela-listas tbody tr { transition: var(--transicao); } .tabela-listas tbody tr:hover td { background-color: var(--cor-tabela-linha-hover) !important; } .coluna-acoes-mobile { display: flex; align-items: center; gap: 0.5rem; flex-wrap: nowrap; } .coluna-acoes-mobile .button.is-small { width: 34px; height: 34px; padding: 0; border-radius: 8px; } .btn-copiar-link-lista { background: var(--cor-fundo-card) !important; color: var(--cor-texto-suave) !important; border: 1px solid var(--cor-borda) !important; transition: var(--transicao) !important; } .btn-copiar-link-lista:hover { background: rgba(83, 203, 191, 0.12) !important; border-color: var(--cor-harmonia-3) !important; color: var(--cor-harmonia-3) !important; } .modal-card-temptask .modal-card-head { background: var(--cor-primaria); border-bottom: none; border-radius: var(--raio-borda) var(--raio-borda) 0 0; } .modal-card-temptask .modal-card-title { color: #fff; font-weight: 700; } .modal-card-temptask .modal-card-head .delete { background: rgba(255, 255, 255, 0.25); } .modal-card-temptask .modal-card-body { border-radius: 0; padding: 1.5rem; background-color: var(--cor-modal-body) !important; color: var(--cor-texto); } .modal-card-temptask .modal-card-body .label { color: var(--cor-texto) !important; } .modal-card-temptask .modal-card-body .input { background-color: var(--cor-input-bg) !important; color: var(--cor-texto) !important; border-color: var(--cor-input-borda) !important; } .modal-card-temptask .modal-card-body .input::placeholder { color: var(--cor-texto-suave) !important; opacity: 0.7; } .modal-card-temptask .modal-card-foot { border-radius: 0 0 var(--raio-borda) var(--raio-borda); border-top: 1px solid var(--cor-borda); background-color: var(--cor-modal-foot) !important; gap: 0.5rem; } .contador-caracteres { font-size: 0.78rem; font-weight: 500; color: var(--cor-texto-suave); font-variant-numeric: tabular-nums; font-family: "JetBrains Mono", monospace; transition: color 0.2s ease; } .contador-caracteres.is-limite { color: var(--cor-secundaria); font-weight: 700; } .btn-modal-cancelar { background-color: transparent !important; border: 1px solid var(--cor-borda) !important; color: var(--cor-texto-suave) !important; font-weight: 500 !important; transition: var(--transicao) !important; } .btn-modal-cancelar:hover { background-color: var(--cor-borda) !important; color: var(--cor-texto) !important; } .editor-container { border-radius: 8px; overflow: hidden; border: 1px solid var(--cor-input-borda); background-color: var(--cor-editor-bg); } .editor-container .ql-toolbar { border: none !important; background: var(--cor-editor-toolbar) !important; border-bottom: 1px solid var(--cor-input-borda) !important; } .editor-container .ql-container { border: none !important; min-height: 120px; font-size: 0.95rem; background-color: var(--cor-editor-bg); } .editor-container .ql-editor { min-height: 120px; padding: 1rem; background-color: var(--cor-editor-bg) !important; color: var(--cor-editor-texto) !important; } .editor-container .ql-editor.ql-blank::before { color: var(--cor-texto-suave) !important; } .editor-container .ql-toolbar .ql-stroke { stroke: var(--cor-texto-suave); } .editor-container .ql-toolbar .ql-fill { fill: var(--cor-texto-suave); } .editor-container .ql-toolbar button:hover .ql-stroke, .editor-container .ql-toolbar button.ql-active .ql-stroke { stroke: var(--cor-harmonia-3) !important; } .editor-container .ql-toolbar button:hover .ql-fill, .editor-container .ql-toolbar button.ql-active .ql-fill { fill: var(--cor-harmonia-3) !important; } .editor-container .ql-toolbar .ql-picker-label { color: var(--cor-texto-suave); } .barra-progresso { height: 6px; border-radius: 3px; overflow: hidden; background: rgba(36, 33, 26, 0.08); } .barra-progresso-fill { height: 100%; border-radius: 3px; background: linear-gradient( 90deg, var(--cor-harmonia-3), var(--cor-harmonia-2) ); transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1); } .tarefa-item { background: var(--cor-fundo-card); border-radius: 10px; border: 1px solid var(--cor-borda); padding: 1rem 1.15rem; transition: var(--transicao); margin-bottom: 0.65rem; color: var(--cor-texto); } .tarefa-item:hover { box-shadow: var(--sombra-card); } .tarefa-item.is-concluida { opacity: 0.65; background: rgba(177, 212, 182, 0.06); } .tarefa-item.is-concluida .tarefa-titulo { text-decoration: line-through; color: var(--cor-texto-suave); } .tarefa-item.is-readonly { opacity: 0.75; } .tarefa-check.is-bloqueada { pointer-events: none; cursor: default; opacity: 0.55; border-style: dashed; } .aviso-readonly { display: flex; align-items: center; gap: 0.5rem; padding: 0.6rem 1rem; border-radius: 8px; background: rgba(250, 119, 133, 0.08); border: 1px solid rgba(250, 119, 133, 0.28); color: var(--cor-secundaria); font-size: 0.82rem; font-weight: 600; margin-bottom: 0.75rem; } .aviso-sincronizacao { display: flex; align-items: center; gap: 0.5rem; padding: 0.6rem 1rem; border-radius: 8px; background: rgba(83, 203, 191, 0.08); border: 1px solid rgba(83, 203, 191, 0.28); color: var(--cor-harmonia-3); font-size: 0.82rem; font-weight: 600; margin-bottom: 1rem; } .tarefa-titulo { font-weight: 600; font-size: 1rem; color: var(--cor-texto); } .tarefa-meta { font-size: 0.78rem; color: var(--cor-texto-suave) !important; } .tarefa-check { width: 22px; height: 22px; border-radius: 50%; border: 2px solid rgba(36, 33, 26, 0.2); cursor: pointer; transition: var(--transicao); display: flex; align-items: center; justify-content: center; flex-shrink: 0; } .tarefa-check:hover { border-color: var(--cor-harmonia-3); background: rgba(83, 203, 191, 0.1); } .tarefa-check.is-checked { background: var(--cor-harmonia-3); border-color: var(--cor-harmonia-3); color: #fff; } .link-area-wrapper { display: flex; align-items: stretch; gap: 0.5rem; } .link-compartilhar { flex: 1; display: flex; align-items: center; background: rgba(83, 203, 191, 0.08); border: 1px dashed rgba(83, 203, 191, 0.4); border-radius: 8px; padding: 0.65rem 1rem; word-break: break-all; font-family: "JetBrains Mono", monospace; font-size: 0.82rem; color: var(--cor-texto-suave); cursor: pointer; transition: var(--transicao); } .link-compartilhar:hover { background: rgba(83, 203, 191, 0.15); border-color: var(--cor-harmonia-3); } #btn-copiar-link { flex-shrink: 0; align-self: stretch; height: auto; padding: 0 1rem; } .estado-vazio { text-align: center; padding: 3rem 1.5rem; } .estado-vazio-icone { font-size: 3.5rem; margin-bottom: 1rem; opacity: 0.3; } .estado-vazio-texto { color: var(--cor-texto); font-size: 1rem; } .feature-icon { width: 56px; height: 56px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; margin-bottom: 1rem; flex-shrink: 0; } .feature-icon.is-rosa { background: rgba(250, 119, 133, 0.12); color: var(--cor-secundaria); } .feature-icon.is-teal { background: rgba(83, 203, 191, 0.12); color: var(--cor-harmonia-3); } .feature-icon.is-verde { background: rgba(177, 212, 182, 0.15); color: #4a7c59; } .feature-icon.is-amarelo { background: rgba(213, 216, 125, 0.18); color: #8a8c3a; } .toast-container { position: fixed; top: 1rem; right: 1rem; z-index: 100; display: flex; flex-direction: column; gap: 0.5rem; pointer-events: none; max-width: 380px; width: calc(100% - 2rem); } .toast-item { pointer-events: auto; border-radius: 10px; box-shadow: 0 4px 20px rgba(36, 33, 26, 0.18); animation: toastIn 0.35s cubic-bezier(0.4, 0, 0.2, 1); border-left: 4px solid var(--cor-harmonia-3); } .toast-item.is-aviso { border-left-color: var(--cor-harmonia-1); } .toast-item.is-erro { border-left-color: var(--cor-secundaria); } .toast-item.is-saindo { animation: toastOut 0.3s cubic-bezier(0.4, 0, 0.2, 1) forwards; } @keyframes toastIn { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } } @keyframes toastOut { from { opacity: 1; transform: translateX(0); } to { opacity: 0; transform: translateX(40px); } } .footer-temptask { background: var(--cor-primaria); color: rgba(255, 255, 255, 0.7); padding: 2rem 1.5rem; flex-shrink: 0; } .footer-temptask a { color: var(--cor-harmonia-3); transition: var(--transicao); } .footer-temptask a:hover { color: #fff; } .navbar-label-mobile { display: none; color: rgba(255, 255, 255, 0.85); font-size: 0.9rem; } .btn-toggle-tema { background: rgba(255, 255, 255, 0.12) !important; border: none !important; color: #fff !important; transition: background 0.2s !important; } .btn-toggle-tema:hover { background: rgba(255, 255, 255, 0.22) !important; color: #fff !important; } [data-tema="escuro"] .button.is-light { background-color: rgba(255, 255, 255, 0.1) !important; color: var(--cor-texto) !important; border-color: var(--cor-borda) !important; } [data-tema="escuro"] .button.is-light:hover { background-color: rgba(255, 255, 255, 0.18) !important; } [data-tema="escuro"] .barra-progresso { background: rgba(255, 255, 255, 0.1); } [data-tema="escuro"] .help { color: var(--cor-texto-suave) !important; } [data-tema="escuro"] .ql-picker-options { background-color: var(--cor-editor-toolbar) !important; border-color: var(--cor-borda) !important; } [data-tema="escuro"] .tarefa-check, [data-tema="escuro"] .tarefa-check-sm { border-color: rgba(255, 255, 255, 0.35); } [data-tema="escuro"] .tarefa-check:hover, [data-tema="escuro"] .tarefa-check-sm:hover { border-color: var(--cor-harmonia-3); background: rgba(83, 203, 191, 0.15); } @media screen and (max-width: 768px) { .tabela-listas { font-size: 0.88rem; } .tabela-listas thead th { font-size: 0.75rem; padding: 0.7rem 0.6rem; } .tabela-listas tbody td { padding: 0.7rem 0.6rem; } .modal-card-temptask .modal-card-body { padding: 1rem; } .tarefa-item { padding: 0.85rem; } .coluna-acoes-mobile { gap: 0.35rem; } .footer-temptask .column { text-align: center; } .footer-temptask .is-justify-content-flex-end { justify-content: center !important; } .navbar-label-mobile { display: inline; } .navbar-item-with-label { display: flex !important; align-items: center; gap: 0.75rem; } } @media screen and (max-width: 480px) { .hero-temptask .title { font-size: 1.65rem !important; } .esconder-mobile-pequeno { display: none !important; } } @keyframes shimmer { 0% { background-position: 0%; } 100% { background-position: 100%; } } .skeleton-line, .skeleton-circle { background: linear-gradient( 90deg, rgba(36, 33, 26, 0.06) 25%, rgba(36, 33, 26, 0.13) 50%, rgba(36, 33, 26, 0.06) 75% ); background-size: 400% 100%; animation: shimmer 1.6s infinite linear; border-radius: 4px; display: block; } .skeleton-circle { width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0; } .skeleton-line { height: 14px; } .tarefa-skeleton { pointer-events: none; user-select: none; } .contador-tarefas-label { color: var(--cor-texto); } .contador-tarefas-label strong { color: var(--cor-harmonia-3); font-weight: 700; } .tarefa-grade { display: flex; flex-wrap: wrap; gap: 0.65rem; } .tarefa-grade-item { background: var(--cor-fundo-card); border-radius: 10px; border: 1px solid var(--cor-borda); padding: 0.85rem; transition: var(--transicao); color: var(--cor-texto); display: flex; flex-direction: column; width: calc((100% - 4 * 0.65rem) / 5); min-width: 0; } .tarefa-grade-item:hover { box-shadow: var(--sombra-card); } .tarefa-grade-item.is-concluida { opacity: 0.65; background: rgba(177, 212, 182, 0.06); } .tarefa-grade-item.is-concluida .tarefa-titulo { text-decoration: line-through; color: var(--cor-texto-suave); } .tarefa-grade-item.is-readonly { opacity: 0.75; } .tarefa-grade-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.5rem; } .tarefa-grade-titulo { font-size: 0.88rem; font-weight: 600; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 0.35rem; } .tarefa-grade-desc { font-size: 0.75rem; color: var(--cor-texto-suave); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 0.4rem; flex: 1; } .tarefa-grade-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 0.35rem; border-top: 1px solid var(--cor-borda); } .tarefa-grade-footer .tarefa-meta { font-size: 0.7rem; } .tarefa-grade-btn-editar { padding: 0.15rem 0.4rem !important; height: auto !important; } .tarefa-check-sm { width: 18px; height: 18px; border-radius: 50%; border: 2px solid rgba(36, 33, 26, 0.2); cursor: pointer; transition: var(--transicao); display: flex; align-items: center; justify-content: center; flex-shrink: 0; } .tarefa-check-sm:hover { border-color: var(--cor-harmonia-3); background: rgba(83, 203, 191, 0.1); } .tarefa-check-sm.is-checked { background: var(--cor-harmonia-3); border-color: var(--cor-harmonia-3); color: #fff; } @media screen and (max-width: 1200px) { .tarefa-grade-item { width: calc((100% - 3 * 0.65rem) / 4); } } @media screen and (max-width: 1024px) { .tarefa-grade-item { width: calc((100% - 2 * 0.65rem) / 3); } } .fade-in { animation: fadeIn 0.4s ease; } @keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } } .pulse { animation: pulse 2s infinite; } @keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.6; } } ::-webkit-scrollbar { width: 6px; } ::-webkit-scrollbar-track { background: transparent; } ::-webkit-scrollbar-thumb { background: rgba(36, 33, 26, 0.15); border-radius: 3px; } ::-webkit-scrollbar-thumb:hover { background: rgba(36, 33, 26, 0.3); } .vitrine-section { padding: 4rem 1.5rem; } .vitrine-section:nth-child(even) { background: rgba(36, 33, 26, 0.02); } .contador-animado { font-variant-numeric: tabular-nums; font-weight: 800; font-size: 2.5rem; color: var(--cor-secundaria); } .cta-grande { padding: 1rem 2.5rem !important; font-size: 1.15rem !important; border-radius: 12px !important; }