/* ============================
Tool System (Global)
============================ */

/* Page Shell */
.tool-page {
  background: var(--bg-color);
  color: var(--text-color);
}

.app-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.page-content {
  flex: 1;
  padding-top: var(--space-xl);
  padding-bottom: calc(var(--space-xl) * 1.5);
}

body:is(.tool-page, [data-tool]):not(
  .index-page,
  .banco-page,
  .orc-page,
  .kit-freelancer-page,
  .planilha-freelancer-page
)
  .page-content {
  padding-bottom: clamp(3rem, 7vw, 5rem);
}

/* Wrapper */
.tool-wrap {
  margin: 0 auto;
  padding: 0 var(--space-lg);
  width: 100%;
}

.tool-wrap.xlarge { max-width: 898px; }
.tool-wrap.large { max-width: 838px; }
.tool-wrap.medium { max-width: 720px; }
.tool-wrap.small { max-width: 638px; }
.tool-wrap.xsmall { max-width: 578px; }

.tool-page-title {
  max-width: 638px;
  margin: 0 auto var(--space-md);
  padding: 0 var(--space-lg);
  color: var(--text-header);
  text-align: center;
}

.tool-shell--compact,
.tool-wrap.tool-shell--compact {
  max-width: var(--container-compact, 620px);
}

.tool-shell--default,
.tool-wrap.tool-shell--default {
  max-width: var(--container-default, 900px);
}

.tool-shell--wide,
.tool-wrap.tool-shell--wide {
  max-width: var(--container-wide, 1180px);
}

.tool-shell--compact,
.tool-shell--default,
.tool-shell--wide {
  margin-inline: auto;
  padding-inline: clamp(var(--space-md), 3vw, var(--space-xl));
  padding-block: clamp(var(--space-lg), 4vw, var(--space-2xl));
}

/* Card */
.tool {
  background: var(--surface-card-bg);
  border: var(--surface-card-border);
  border-radius: var(--surface-card-radius);
  padding: var(--space-xl);
  box-shadow: var(--surface-shadow);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.tool > * {
  min-width: 0;
}

/* Header */
.tool-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  max-width: 100%;
  text-align: center;
}

/* Body */
.tool-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  align-items: center;
}

/* 🔥 POMODORO FIX */
.tool-pomodoro-controls {
  display: flex;
  gap: var(--space-sm);
  justify-content: center;
}

.tool-pomodoro-audio {
  display: flex;
  gap: 10px;
  justify-content: center;
  align-items: center;
  margin-top: var(--space-sm);
}

/* Context */
.tool-context {
  margin-top: var(--space-lg);
  font-size: 0.95rem;
  color: var(--muted);
}

.tool-header ul,
.tool-context ul {
  margin: 12px auto 16px;
  padding-left: 22px;
  width: fit-content;
  max-width: 520px;
  text-align: left;
  list-style-position: outside;
}

.tool-header li,
.tool-context li {
  display: list-item;
  margin-bottom: 6px;
  line-height: 1.5;
  text-align: left;
}

/* Ferramentas hub */
.ferramentas-page .tool-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap: var(--space-md);
  width: 100%;
}

.ferramentas-page .tool-grid > .card {
  display: flex;
  min-width: 0;
  height: 100%;
  flex-direction: column;
  gap: var(--space-xs);
  margin-bottom: 0;
  color: inherit;
  text-decoration: none;
}

.ferramentas-page .tool-grid > .card::before,
.ferramentas-page .tool-grid > .card::after {
  content: none;
}

.ferramentas-page .tool-grid > .card :is(h2, h3, p) {
  margin: 0;
}

.ferramentas-page .tool-grid > .card :is(h2, h3) {
  color: var(--text-header);
  font-size: 1rem;
  line-height: 1.25;
}

.ferramentas-page .tool-grid > .card p {
  color: var(--muted);
  line-height: 1.55;
}

.ferramentas-page .tool-grid > .card:hover {
  transform: var(--surface-hover-transform);
}

.ferramentas-page .tool-grid > .card:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
  border-color: color-mix(in srgb, var(--primary) 40%, var(--surface-card-border-color));
}

/* Footer fix */
.tool-page .site-footer {
  margin-top: auto;
}

/* Mobile */
@media (width <= 768px) {
  .tool-wrap {
    padding-left: var(--mobile-container-padding, var(--space-md));
    padding-right: var(--mobile-container-padding, var(--space-md));
  }

  .page-content > .tool-wrap.small:not([class*="tool-shell"]) {
    width: calc(
      100% - var(--mobile-container-padding, var(--space-md)) -
        var(--mobile-container-padding, var(--space-md))
    );
    padding-left: 0;
    padding-right: 0;
  }

  .tool-page-title {
    padding-left: var(--mobile-container-padding, var(--space-md));
    padding-right: var(--mobile-container-padding, var(--space-md));
  }

  .tool {
    gap: var(--mobile-stack-gap, var(--space-md));
    padding: var(--mobile-card-padding, var(--space-lg));
  }

  .tool-shell--compact,
  .tool-shell--default,
  .tool-shell--wide {
    padding-inline: var(--mobile-container-padding, var(--space-md));
    padding-block: var(--mobile-section-gap, var(--space-lg));
  }

  .tool-context {
    margin-top: var(--mobile-stack-gap, var(--space-sm));
  }

  .ferramentas-page .tool-grid {
    gap: var(--mobile-card-gap, var(--space-sm));
  }
}
