/* 
   GTrack-On - Ferramentas (Calculadoras)
   Estilos compartilhados para todas as ferramentas e calculadoras
*/

/* ===== VARIÁVEIS ESPECÍFICAS ===== */
:root {
    --tools-bg: #f5f5f5;
    --tools-white: #ffffff;
    --tools-border: var(--gto-border);
    --tools-text: var(--gto-text);
    --tools-text-muted: #666666;
    --tools-red: var(--gto-primary);
    --tools-red-light: rgba(220, 20, 60, 0.07);
    --tools-red-border: rgba(220, 20, 60, 0.22);
    --tools-green: var(--gto-secondary);
    --tools-green-light: rgba(34, 197, 94, 0.07);
    --tools-green-border: rgba(34, 197, 94, 0.25);
    --tools-yellow: #d48a00;
    --tools-yellow-light: rgba(212, 138, 0, 0.07);
    --tools-yellow-border: rgba(212, 138, 0, 0.3);
    --tools-radius: 12px;
    --tools-radius-lg: 18px;
    --tools-shadow: 0 2px 12px rgba(0,0,0,0.07);
}

/* ===== RESET ===== */
.tools-wrapper * { box-sizing: border-box; }
.tools-wrapper { margin: 0; padding: 0; }

/* ===== WRAPPER PRINCIPAL ===== */
.tools-wrapper {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background: var(--tools-bg);
    color: var(--tools-text);
    max-width: 740px;
    margin: 0 auto;
    padding: 48px 20px 72px;
}

/* ===== HERO ===== */
.tools-hero { 
    text-align: center; 
    margin-bottom: 40px; 
}

.tools-hero-badge {
    display: inline-flex; 
    align-items: center; 
    gap: 8px;
    background: var(--tools-red-light); 
    border: 1px solid var(--tools-red-border);
    color: var(--tools-red); 
    font-family: monospace;
    font-size: 11px; 
    letter-spacing: 0.1em; 
    text-transform: uppercase;
    padding: 6px 16px; 
    border-radius: 100px; 
    margin-bottom: 16px;
}

.tools-hero h1 {
    font-size: clamp(26px, 5vw, 40px);
    font-weight: 800; 
    line-height: 1.15; 
    color: var(--gto-dark); 
    margin-bottom: 10px;
}

.tools-hero h1 span { 
    color: var(--tools-red); 
}

.tools-hero p { 
    color: var(--tools-text-muted); 
    font-size: 15px; 
    max-width: 460px; 
    margin: 0 auto; 
}

/* ===== TABS ===== */
.tools-tabs {
    display: flex; 
    gap: 4px; 
    background: var(--tools-white);
    border: 1px solid var(--tools-border); 
    border-radius: var(--tools-radius);
    padding: 4px; 
    margin-bottom: 24px; 
    box-shadow: var(--tools-shadow);
}

.tools-tab-btn {
    flex: 1; 
    padding: 12px 16px; 
    background: transparent; 
    border: none;
    color: var(--tools-text-muted); 
    font-weight: 600; 
    font-size: 14px; 
    cursor: pointer;
    border-radius: 8px; 
    transition: all 0.2s;
    display: flex; 
    align-items: center; 
    justify-content: center; 
    gap: 8px;
}

.tools-tab-btn:hover { 
    background: var(--tools-bg); 
    color: var(--tools-text); 
}

.tools-tab-btn.active { 
    background: var(--tools-green); 
    color: #fff; 
}

/* ===== PAINÉIS ===== */
.tools-tab-panel { 
    display: none; 
}

.tools-tab-panel.active { 
    display: block; 
}

/* ===== CARD ===== */
.tools-card {
    background: var(--tools-white); 
    border: 1px solid var(--tools-border);
    border-radius: var(--tools-radius-lg); 
    padding: 28px;
    margin-bottom: 16px; 
    box-shadow: var(--tools-shadow);
}

.tools-card-title {
    font-size: 16px; 
    font-weight: 700;
    color: var(--gto-dark); 
    margin-bottom: 20px;
    display: flex; 
    align-items: center; 
    gap: 8px;
}

.tools-card-title .tools-icon { 
    color: var(--tools-red); 
}

/* ===== FORM ===== */
.tools-form-grid { 
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: 16px; 
}

@media (max-width: 540px) {
    .tools-form-grid { 
        grid-template-columns: 1fr; 
    }
    .tools-tabs { 
        flex-direction: column; 
    }
}

.tools-form-group { 
    display: flex; 
    flex-direction: column; 
    gap: 6px; 
}

.tools-label {
    font-size: 12px; 
    font-weight: 600; 
    letter-spacing: 0.05em;
    text-transform: uppercase; 
    color: var(--tools-text-muted);
    display: flex; 
    align-items: center; 
    gap: 5px;
}

.tools-tip { 
    cursor: help; 
    color: #bbb; 
    font-size: 13px; 
    position: relative; 
}

.tools-tip:hover::after {
    content: attr(data-tip); 
    position: absolute; 
    bottom: 24px; 
    left: 50%;
    transform: translateX(-50%); 
    background: #222; 
    color: #fff;
    font-size: 11px; 
    font-weight: 400; 
    letter-spacing: 0;
    text-transform: none; 
    padding: 8px 12px; 
    border-radius: 8px;
    width: 220px; 
    text-align: center; 
    z-index: 99; 
    line-height: 1.5;
    pointer-events: none;
}

.tools-input-wrap { 
    position: relative; 
    display: flex; 
    align-items: center; 
}

.tools-pfx, .tools-sfx {
    position: absolute; 
    color: var(--tools-text-muted);
    font-family: monospace; 
    font-size: 14px; 
    pointer-events: none;
}

.tools-pfx { 
    left: 13px; 
}

.tools-sfx { 
    right: 13px; 
}

.tools-input {
    width: 100%; 
    background: var(--tools-bg); 
    border: 1.5px solid var(--tools-border);
    border-radius: var(--tools-radius); 
    color: var(--tools-text);
    font-family: monospace; 
    font-size: 16px;
    padding: 13px 14px 13px 36px;
    outline: none; 
    transition: border-color 0.2s, box-shadow 0.2s;
    -moz-appearance: textfield;
}

.tools-input::-webkit-outer-spin-button,
.tools-input::-webkit-inner-spin-button { 
    -webkit-appearance: none; 
}

.tools-input:focus {
    border-color: var(--tools-red); 
    box-shadow: 0 0 0 3px rgba(220,20,60,0.1); 
    background: #fff;
}

.tools-input.no-pfx { 
    padding-left: 14px; 
}

.tools-input.has-sfx { 
    padding-right: 36px; 
}

/* ===== BOTÃO ===== */
.tools-btn {
    width: 100%; 
    padding: 16px; 
    background: var(--tools-green); 
    color: #fff;
    border: none; 
    border-radius: var(--tools-radius);
    font-size: 15px; 
    font-weight: 700; 
    cursor: pointer; 
    transition: all 0.2s;
    margin-top: 10px; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    gap: 8px;
}

.tools-btn:hover { 
    background: #16a34a; 
    transform: translateY(-1px); 
    box-shadow: 0 6px 20px rgba(34,197,94,0.25); 
}

.tools-btn:active { 
    transform: translateY(0); 
}

/* ===== RESULT CARDS ===== */
.tools-results-grid { 
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: 14px; 
    margin-bottom: 16px; 
}

@media (max-width: 480px) { 
    .tools-results-grid { 
        grid-template-columns: 1fr; 
    } 
}

.tools-result-card {
    border-radius: var(--tools-radius-lg); 
    padding: 24px 18px;
    text-align: center; 
    box-shadow: var(--tools-shadow);
}

.tools-result-card.r-red { 
    background: var(--tools-red-light); 
    border: 1.5px solid var(--tools-red-border); 
}

.tools-result-card.r-green { 
    background: var(--tools-green-light); 
    border: 1.5px solid var(--tools-green-border); 
}

.tools-result-label {
    font-family: monospace; 
    font-size: 11px;
    letter-spacing: 0.1em; 
    text-transform: uppercase; 
    color: var(--tools-text-muted); 
    margin-bottom: 8px;
}

.tools-result-value {
    font-size: 38px;
    font-weight: 800; 
    line-height: 1; 
    margin-bottom: 6px;
}

.tools-rv-red { 
    color: var(--tools-red); 
}

.tools-rv-green { 
    color: var(--tools-green); 
}

.tools-result-desc { 
    font-size: 12px; 
    color: var(--tools-text-muted); 
    line-height: 1.5; 
}

/* ===== BREAKDOWN ===== */
.tools-breakdown {
    background: var(--tools-white); 
    border: 1px solid var(--tools-border);
    border-radius: var(--tools-radius-lg); 
    padding: 20px 22px;
    box-shadow: var(--tools-shadow); 
    margin-bottom: 14px;
}

.tools-bd-title {
    font-family: monospace; 
    font-size: 11px;
    letter-spacing: 0.1em; 
    text-transform: uppercase;
    color: var(--tools-text-muted); 
    margin-bottom: 14px;
}

.tools-bd-row {
    display: flex; 
    justify-content: space-between; 
    align-items: center;
    padding: 9px 0; 
    border-bottom: 1px solid var(--tools-border); 
    font-size: 13px;
}

.tools-bd-row:last-child { 
    border-bottom: none; 
}

.tools-b-label { 
    color: var(--tools-text-muted); 
}

.tools-b-val { 
    font-family: monospace; 
    font-weight: 500; 
    color: var(--tools-text); 
}

.tools-b-val.bv-red { 
    color: var(--tools-red); 
    font-weight: 700; 
}

.tools-b-val.bv-green { 
    color: var(--tools-green); 
    font-weight: 700; 
}

/* ===== INFO BOX ===== */
.tools-info-box {
    background: var(--tools-bg); 
    border: 1px solid var(--tools-border);
    border-left: 3px solid var(--tools-red); 
    border-radius: var(--tools-radius);
    padding: 14px 18px; 
    font-size: 13px; 
    color: var(--tools-text-muted); 
    line-height: 1.7;
}

.tools-info-box strong { 
    color: var(--tools-text); 
}

/* ===== STATUS BANNER ===== */
.tools-status-banner {
    display: flex; 
    align-items: center; 
    gap: 16px;
    padding: 18px 22px; 
    border-radius: var(--tools-radius-lg);
    margin-bottom: 16px; 
    box-shadow: var(--tools-shadow);
}

.tools-status-banner.lucro { 
    background: var(--tools-green-light); 
    border: 1.5px solid var(--tools-green-border); 
}

.tools-status-banner.prejuizo { 
    background: var(--tools-red-light);  
    border: 1.5px solid var(--tools-red-border); 
}

.tools-status-banner.neutro { 
    background: var(--tools-yellow-light); 
    border: 1.5px solid var(--tools-yellow-border); 
}

.tools-s-icon { 
    font-size: 30px; 
    flex-shrink: 0; 
}

.tools-s-text h3 { 
    font-size: 17px; 
    font-weight: 700; 
    margin-bottom: 2px; 
}

.tools-status-banner.lucro .tools-s-text h3 { 
    color: var(--tools-green); 
}

.tools-status-banner.prejuizo .tools-s-text h3 { 
    color: var(--tools-red); 
}

.tools-status-banner.neutro .tools-s-text h3 { 
    color: var(--tools-yellow); 
}

.tools-s-text p { 
    font-size: 13px; 
    color: var(--tools-text-muted); 
}

/* ===== COMPARE GRID ===== */
.tools-compare-grid { 
    display: grid; 
    grid-template-columns: 1fr 1fr 1fr; 
    gap: 12px; 
    margin-bottom: 14px; 
}

@media (max-width: 540px) { 
    .tools-compare-grid { 
        grid-template-columns: 1fr; 
    } 
}

.tools-compare-card {
    background: var(--tools-white); 
    border: 1px solid var(--tools-border);
    border-radius: var(--tools-radius); 
    padding: 16px; 
    text-align: center; 
    box-shadow: var(--tools-shadow);
}

.tools-c-label { 
    font-size: 11px; 
    font-family: monospace; 
    letter-spacing: 0.08em; 
    text-transform: uppercase; 
    color: var(--tools-text-muted); 
    margin-bottom: 6px; 
}

.tools-c-val { 
    font-size: 21px; 
    font-weight: 800; 
    color: var(--tools-text); 
}

.tools-c-sub { 
    font-size: 11px; 
    color: var(--tools-text-muted); 
    margin-top: 3px; 
}

.tools-compare-card.pos .tools-c-val { 
    color: var(--tools-green); 
}

.tools-compare-card.neg .tools-c-val { 
    color: var(--tools-red); 
}

.tools-compare-card.neu .tools-c-val { 
    color: var(--tools-yellow); 
}

.tools-compare-card.ideal .tools-c-val { 
    color: var(--tools-red); 
}

/* ===== BARRA VISUAL ===== */
.tools-bar-wrap {
    background: var(--tools-white); 
    border: 1px solid var(--tools-border);
    border-radius: var(--tools-radius); 
    padding: 18px 20px;
    margin-bottom: 14px; 
    box-shadow: var(--tools-shadow);
}

.tools-bar-header {
    display: flex; 
    justify-content: space-between; 
    font-size: 12px;
    color: var(--tools-text-muted); 
    margin-bottom: 10px; 
    font-family: monospace;
}

.tools-bar-track {
    width: 100%; 
    height: 10px; 
    background: var(--tools-bg);
    border-radius: 100px; 
    position: relative; 
    overflow: hidden;
}

.tools-bar-fill {
    height: 100%; 
    border-radius: 100px;
    transition: width 0.5s ease; 
    min-width: 4px; 
    max-width: 100%;
}

.tools-bar-fill.good { 
    background: linear-gradient(90deg, var(--tools-green), #27ae60); 
}

.tools-bar-fill.bad { 
    background: linear-gradient(90deg, var(--tools-red), #e74c3c); 
}

.tools-bar-fill.neu { 
    background: linear-gradient(90deg, var(--tools-yellow), #f39c12); 
}

.tools-bar-ideal-line {
    position: absolute; 
    top: -3px; 
    bottom: -3px;
    width: 2px; 
    background: var(--tools-red); 
    border-radius: 2px;
}

/* ===== EMPTY STATE ===== */
.tools-empty-state {
    text-align: center; 
    padding: 40px 20px; 
    color: #999;
    border: 2px dashed var(--tools-border); 
    border-radius: var(--tools-radius-lg);
}
