/* Price calculators (SEO / GEO / PBN) — shared, scoped under .calc, on site tokens. */
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

.calc { --calc-radius: 14px; }

/* Breadcrumbs + tool cards (shared with hub markup; not scoped to .calc) */
.breadcrumbs ol { display: flex; flex-wrap: wrap; gap: .5rem; font-family: var(--mono); font-size: var(--fs-xs); color: var(--text-3); margin: 1.5rem 0; }
.breadcrumbs li + li::before { content: "/"; margin-right: .5rem; color: var(--text-4); }
.breadcrumbs a:hover { color: var(--text); }
.tools-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr)); gap: 1rem; margin-top: 2rem; }
.tool-card { display: flex; flex-direction: column; gap: .5rem; padding: 1.5rem; border: 1px solid var(--line); border-radius: var(--calc-radius); background: var(--ink-1); transition: border-color var(--t-fast); height: 100%; }
a.tool-card:hover { border-color: var(--text-3); }
.tool-card__title { font-weight: 600; }
.tool-card__desc { color: var(--text-3); font-size: var(--fs-sm); }
.tool-card__arr { color: var(--green-bright); margin-top: auto; }
.tool-card--soon { opacity: .5; }

/* Header */
.calc__head { margin-bottom: 2.5rem; }
.calc__head h1 { font-size: var(--fs-display); line-height: 1.05; margin: 0 0 1rem; }
.calc__year { color: var(--green-bright); }
.calc__lede { font-size: var(--fs-lede); color: var(--text-2); }
.calc__badges { display: flex; flex-wrap: wrap; gap: .5rem 1rem; margin-top: 1.25rem; font-family: var(--mono); font-size: var(--fs-xs); color: var(--text-3); }
.calc__badges a { color: var(--text-2); border-bottom: 1px solid var(--line-2); }

/* TOC */
.calc__toc { border: 1px solid var(--line); border-radius: var(--calc-radius); background: var(--ink-1); padding: 1rem 1.25rem; margin-bottom: 2.5rem; }
.calc__toc summary { font-family: var(--mono); font-size: var(--fs-xs); letter-spacing: .12em; text-transform: uppercase; color: var(--text-3); cursor: pointer; }
.calc__toc ol { margin-top: .75rem; display: grid; gap: .4rem; }
.calc__toc a { color: var(--text-2); font-size: var(--fs-sm); }
.calc__toc a:hover { color: var(--green-bright); }

/* Sections + prose */
.calc section { scroll-margin-top: 90px; margin-bottom: 3.5rem; }
.calc h2 { font-size: var(--fs-h2); line-height: 1.1; margin: 0 0 1rem; }
.calc h3 { font-size: var(--fs-h3); margin: 1.5rem 0 .5rem; }
.calc p { color: var(--text-2); line-height: 1.6; }
.calc a[href^="http"] { color: var(--text); border-bottom: 1px solid var(--line-2); }
.calc a[href^="http"]:hover { border-color: var(--green-bright); }

/* Widget */
.calc__calc { border: 1px solid var(--line); border-radius: var(--calc-radius); background: var(--ink-1); padding: clamp(1.25rem, 4vw, 2rem); }
.calc-form { display: grid; gap: 1.25rem; }
.calc-grid { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .calc-grid { grid-template-columns: 1fr 1fr; } }
.calc-field { display: grid; gap: .35rem; }
.calc-field label { font-size: var(--fs-sm); color: var(--text-2); font-weight: 500; }
.calc-field .hint { font-size: var(--fs-xs); color: var(--text-3); }
.calc-input { position: relative; display: flex; align-items: center; gap: .5rem; border: 1px solid var(--line-2); border-radius: 10px; background: var(--ink); padding: .65rem .8rem; transition: border-color var(--t-fast); }
.calc-input:focus-within { border-color: var(--green); }
.calc-input input, .calc-input select { width: 100%; background: none; border: 0; color: var(--text); font: inherit; min-width: 0; }
.calc-input input:focus, .calc-input select:focus { outline: none; }
.calc-input input[type="number"] { appearance: textfield; -moz-appearance: textfield; }
.calc-input input[type="number"]::-webkit-outer-spin-button,
.calc-input input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.calc-input select { background: var(--ink); color: var(--text); cursor: pointer; appearance: none; -webkit-appearance: none; padding-right: 1.25rem; background-image: linear-gradient(45deg, transparent 50%, var(--text-3) 50%), linear-gradient(135deg, var(--text-3) 50%, transparent 50%); background-position: right .35rem center, right .1rem center; background-size: .35rem .35rem, .35rem .35rem; background-repeat: no-repeat; }
.calc-input select option { background: var(--ink-2); color: var(--text); }
.calc-input .unit { font-family: var(--mono); font-size: var(--fs-xs); color: var(--text-3); white-space: nowrap; }

/* Extra-budgets group */
.calc-extra { border-top: 1px solid var(--line); padding-top: 1.1rem; }
.calc-extra__label { font-size: var(--fs-sm); color: var(--text-2); font-weight: 500; margin: 0 0 .85rem; }

/* Mode segmented control (PBN) */
.calc-modes { display: grid; gap: .5rem; grid-template-columns: 1fr; }
@media (min-width: 600px) { .calc-modes { grid-template-columns: repeat(3, 1fr); } }
.calc-mode { position: relative; }
.calc-mode input { position: absolute; opacity: 0; pointer-events: none; }
.calc-mode label { display: block; border: 1px solid var(--line-2); border-radius: 10px; padding: .8rem 1rem; cursor: pointer; transition: border-color var(--t-fast), background var(--t-fast); }
.calc-mode label b { display: block; font-size: var(--fs-sm); color: var(--text); }
.calc-mode label span { font-size: var(--fs-xs); color: var(--text-3); }
.calc-mode input:checked + label { border-color: var(--green); background: var(--green-soft); }
.calc-mode input:focus-visible + label { outline: 2px solid var(--green-bright); outline-offset: 2px; }

/* Checkbox add-ons */
.calc-checks { display: grid; gap: .75rem; }
.calc-check { display: flex; gap: .65rem; align-items: flex-start; border: 1px solid var(--line); border-radius: 10px; background: var(--ink); padding: .8rem 1rem; cursor: pointer; }
.calc-check input { margin-top: .15rem; width: 1.1rem; height: 1.1rem; accent-color: var(--green); flex: none; }
.calc-check__txt b { display: block; font-size: var(--fs-sm); color: var(--text); font-weight: 500; }
.calc-check__txt span { font-size: var(--fs-xs); color: var(--text-3); }

/* Results */
.calc-result { margin-top: 1.5rem; display: grid; gap: 1.5rem; }
.calc-kpis { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 600px) { .calc-kpis { grid-template-columns: repeat(2, 1fr); } }
.calc-kpi { border: 1px solid var(--line); border-radius: 12px; padding: 1.1rem 1.25rem; background: var(--ink-2); }
.calc-kpi__label { font-family: var(--mono); font-size: var(--fs-xs); letter-spacing: .1em; text-transform: uppercase; color: var(--text-3); }
.calc-kpi__value { font-size: clamp(1.6rem, 4.5vw, 2.4rem); font-weight: 700; line-height: 1.1; margin-top: .35rem; }
.calc-kpi--accent .calc-kpi__value { color: var(--green-bright); }
.calc-kpi__range { font-size: var(--fs-sm); color: var(--text-3); margin-top: .35rem; font-variant-numeric: tabular-nums; }

.calc-result__text { border-left: 2px solid var(--green); padding: .5rem 0 .5rem 1rem; color: var(--text-2); font-size: var(--fs-body); }

.calc-warns { display: grid; gap: .6rem; }
.calc-warn { border: 1px solid var(--line-2); border-left: 3px solid #e0a23d; border-radius: 8px; background: var(--ink); padding: .7rem 1rem; color: var(--text-2); font-size: var(--fs-sm); }
.calc-warn--risk { border-left-color: #e0533d; }

.calc-actions { display: flex; flex-wrap: wrap; gap: .75rem; }

.calc-table-d summary { cursor: pointer; font-size: var(--fs-sm); color: var(--text-2); padding: .5rem 0; }
.calc-table-wrap { overflow-x: auto; }
.calc-table { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); font-variant-numeric: tabular-nums; }
.calc-table th, .calc-table td { padding: .55rem .65rem; text-align: right; border-bottom: 1px solid var(--line); white-space: nowrap; }
.calc-table th:first-child, .calc-table td:first-child { text-align: left; }
.calc-table thead th { color: var(--text-3); font-weight: 600; font-family: var(--mono); font-size: var(--fs-xs); }

/* Content blocks */
.calc-box { border: 1px solid var(--line); border-left: 3px solid var(--green); border-radius: 10px; background: var(--ink-1); padding: 1.25rem 1.5rem; }
.calc-box h2, .calc-box h3 { margin-top: 0; }
.calc-takeaways { display: grid; gap: .6rem; margin-top: .75rem; }
.calc-takeaways li { padding-left: 1.4rem; position: relative; color: var(--text-2); }
.calc-takeaways li::before { content: "▸"; position: absolute; left: 0; color: var(--green-bright); }

.calc-steps { counter-reset: s; display: grid; gap: .85rem; margin: 1rem 0; }
.calc-steps li { counter-increment: s; padding-left: 2.2rem; position: relative; color: var(--text-2); }
.calc-steps li::before { content: counter(s); position: absolute; left: 0; top: 0; width: 1.6rem; height: 1.6rem; display: grid; place-items: center; border-radius: 50%; background: var(--green-soft); color: var(--green-bright); font-family: var(--mono); font-size: var(--fs-xs); }

.calc-formula { font-family: var(--mono); font-size: var(--fs-sm); background: var(--ink); border: 1px solid var(--line); border-radius: 10px; padding: 1rem; overflow-x: auto; color: var(--text-2); line-height: 1.7; }

.calc-table.calc-table--ref th, .calc-table.calc-table--ref td { white-space: normal; }

.calc-faq details { border-bottom: 1px solid var(--line); padding: .25rem 0; }
.calc-faq summary { padding: .9rem 0; font-weight: 500; cursor: pointer; font-size: var(--fs-body); }
.calc-faq details[open] summary { color: var(--green-bright); }
.calc-faq p { padding: 0 0 1rem; }

.calc-author { display: flex; gap: 1.25rem; flex-wrap: wrap; align-items: center; border: 1px solid var(--line); border-radius: var(--calc-radius); background: var(--ink-1); padding: 1.5rem; }
.calc-author img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; }
.calc-author__name { font-weight: 600; font-size: var(--fs-h3); }
.calc-author__role { color: var(--text-3); font-size: var(--fs-sm); }
.calc-author__links { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: .5rem; font-family: var(--mono); font-size: var(--fs-xs); }

.calc-related { display: grid; gap: 1rem; grid-template-columns: 1fr; margin-top: 1rem; }
@media (min-width: 600px) { .calc-related { grid-template-columns: 1fr 1fr; } }
.calc-updated { color: var(--text-3); font-size: var(--fs-sm); }
.calc-disclaimer { border: 1px dashed var(--line-2); border-radius: 10px; padding: 1.1rem 1.25rem; color: var(--text-3); font-size: var(--fs-sm); margin-top: 2.5rem; margin-bottom: 3.5rem; }
