:root {
  --bg: #0f1419;
  --surface: #1a2332;
  --border: #2d3a4f;
  --text: #e8edf5;
  --muted: #9aa8bc;
  --accent: #c9a227;
  --accent-hover: #e0b82e;
  --success: #3ecf8e;
  --error: #ff6b6b;
  --radius: 12px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Segoe UI", system-ui, sans-serif;
  background: linear-gradient(180deg, #0a0e14 0%, var(--bg) 40%);
  color: var(--text);
  min-height: 100vh;
}
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }
.container { width: min(1100px, 92%); margin: 0 auto; }
.site-header {
  border-bottom: 1px solid var(--border);
  background: rgba(15,20,25,.9);
  backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 10;
}
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: 1rem 0; }
.logo { display: inline-flex; align-items: center; flex-shrink: 0; }
.logo-img, .hero-logo, .footer-logo, .auth-logo { display: block; width: auto; max-width: 100%; object-fit: contain; }
.hero-brand { margin-bottom: 1rem; }
.hero-logo { margin: 0 auto; filter: drop-shadow(0 8px 24px rgba(0,0,0,.45)); }
.footer-brand { display: flex; flex-direction: column; align-items: center; gap: .85rem; }
.footer-logo { opacity: .9; filter: drop-shadow(0 4px 12px rgba(0,0,0,.35)); }
.auth-brand { text-align: center; margin-bottom: 1rem; }
.auth-logo { margin: 0 auto; filter: drop-shadow(0 6px 18px rgba(0,0,0,.4)); }
.site-nav { display: flex; gap: 1rem; align-items: center; }
.nav-toggle {
  display: none; flex-direction: column; justify-content: center; gap: 5px;
  width: 2.5rem; height: 2.5rem; padding: 0; border-radius: 8px;
  border: 1px solid var(--border); background: transparent; cursor: pointer;
}
.nav-toggle-bar {
  display: block; width: 1.15rem; height: 2px; margin: 0 auto;
  background: var(--text); border-radius: 2px; transition: transform .2s, opacity .2s;
}
.nav-toggle.is-active .nav-toggle-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-active .nav-toggle-bar:nth-child(2) { opacity: 0; }
.nav-toggle.is-active .nav-toggle-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
main.container { padding: 2rem 0 4rem; }
.hero { text-align: center; padding: 3rem 0 2rem; }
.hero h1 { font-size: clamp(1.8rem, 4vw, 2.6rem); margin-bottom: .75rem; }
.hero p { color: var(--muted); max-width: 620px; margin: 0 auto 1.5rem; }
.hero-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.features { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; margin-top: 2rem; }
.features article { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem; }
.btn {
  display: inline-block; background: var(--accent); color: #111;
  border: none; border-radius: 8px; padding: .7rem 1.2rem;
  font-weight: 600; cursor: pointer; text-align: center;
}
.btn:hover { background: var(--accent-hover); color: #111; }
.btn-secondary { background: transparent; color: var(--text); border: 1px solid var(--border); }
.btn-secondary:hover { border-color: var(--accent); color: var(--accent); }
.btn-small { padding: .45rem .8rem; font-size: .9rem; }
.auth-card, .calculator, .pricing { max-width: 720px; margin: 0 auto; }
.pricing-wide { max-width: 1080px; }
.pricing-lead { margin: -.25rem 0 1.25rem; text-align: center; }
.auth-card, .calc-form, .results, .price-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.5rem;
}
.form label { display: block; margin-bottom: 1rem; }
.form input, .form select, .calc-form input, .calc-form select {
  width: 100%; margin-top: .35rem; padding: .65rem .75rem;
  border-radius: 8px; border: 1px solid var(--border);
  background: #111822; color: var(--text);
}
.form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; }
.checkbox { display: flex !important; align-items: center; gap: .5rem; }
.alert { padding: .75rem 1rem; border-radius: 8px; background: #2a3548; }
.alert-error { background: rgba(255,107,107,.15); color: var(--error); }
.alert-success { background: rgba(62,207,142,.12); color: var(--success); }
.muted { color: var(--muted); }
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; margin-top: 1.5rem; }
.pricing-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
  align-items: stretch;
}
.price-card {
  display: flex;
  flex-direction: column;
  position: relative;
}
.price-card h2 { margin-top: 0; }
.price-card-desc { min-height: 2.6rem; color: var(--muted); font-size: .95rem; }
.price-card-value {
  margin: -.35rem 0 .5rem;
  font-size: .85rem;
  font-weight: 600;
  color: var(--success);
}
.price-card-cta { margin-top: auto; padding-top: 1.25rem; }
.price-card-cta .btn-block { width: 100%; text-align: center; }
.price-card-active-label {
  margin: 0;
  text-align: center;
  font-weight: 700;
  font-size: .95rem;
  color: var(--error);
}
.price-card .price { font-size: 2rem; font-weight: 700; color: var(--accent); margin: .5rem 0; }
.price-card .price span { font-size: 1rem; font-weight: 500; color: var(--muted); }
.price-card ul { margin: 0; padding-left: 1.1rem; flex: 1; }
.price-card ul li { margin-bottom: .35rem; color: var(--muted); font-size: .92rem; }
.price-card.featured {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 16px 48px rgba(212, 175, 55, .12);
  background: linear-gradient(180deg, rgba(212, 175, 55, .08) 0%, var(--surface) 45%);
}
.price-card-best-badge {
  position: absolute;
  top: -.65rem;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent);
  color: #111;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .3rem .75rem;
  border-radius: 999px;
  white-space: nowrap;
}
.trial-badge {
  display: inline-block; background: var(--accent); color: #111;
  font-size: 0.8rem; font-weight: 700; padding: 0.2rem 0.6rem;
  border-radius: 999px; margin-bottom: 0.5rem;
}
.results { margin-top: 1.5rem; }
.results.hidden { display: none; }
.result-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: .75rem; }
.result-card { background: #111822; border-radius: 8px; padding: 1rem; }
.result-card span { display: block; color: var(--muted); font-size: .85rem; }
.result-card strong { font-size: 1.3rem; }
.suggestions {
  position: absolute; z-index: 5; background: #111822;
  border: 1px solid var(--border); border-radius: 8px;
  width: min(360px, 90vw); max-height: 220px; overflow: auto; display: none;
}
.suggestions button {
  display: block; width: 100%; text-align: left; background: none; border: none;
  color: var(--text); padding: .55rem .75rem; cursor: pointer;
}
.suggestions button:hover { background: #1c2738; }
.site-footer { border-top: 1px solid var(--border); padding: 1.5rem 0; color: var(--muted); font-size: .9rem; text-align: center; }

.calculators-hub { max-width: 820px; margin: 0 auto; }
.calc-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; margin-top: 1.5rem; }
.calc-card {
  display: block; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.5rem; color: var(--text);
  position: relative; transition: border-color .2s;
}
.calc-card:hover { border-color: var(--accent); color: var(--text); }
.calc-card.featured { border-color: var(--accent); }
.calc-card h2 { margin: 0 0 .5rem; font-size: 1.2rem; }
.calc-card p { margin: 0; color: var(--muted); font-size: .95rem; }
.calc-card-cta { display: inline-block; margin-top: 1rem; font-size: .85rem; font-weight: 600; color: var(--accent); }
.calc-card-badge {
  position: absolute; top: .75rem; right: .75rem;
  background: var(--accent); color: #111; font-size: .7rem;
  font-weight: 700; padding: .2rem .5rem; border-radius: 4px;
}
.calc-breadcrumb { margin-bottom: .5rem; font-size: .9rem; color: var(--muted); }
.calc-breadcrumb a { color: var(--muted); }
.calc-breadcrumb a:hover { color: var(--accent); }
.recipe-preview {
  margin-top: 1.5rem; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1rem 1.25rem;
}
.recipe-preview.hidden { display: none; }
.recipe-preview h3 { margin: 0 0 .75rem; font-size: 1rem; }
.recipe-preview ul { margin: 0; padding-left: 1.2rem; color: var(--muted); }
.materials-table-wrap { overflow-x: auto; margin-top: 1rem; }
.materials-table { width: 100%; border-collapse: collapse; font-size: .95rem; }
.materials-table th, .materials-table td {
  padding: .6rem .75rem; text-align: left; border-bottom: 1px solid var(--border);
}
.materials-table th { color: var(--muted); font-weight: 600; font-size: .85rem; }
.materials-table td strong { color: var(--success); }

.lang-switch {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 2.2rem; padding: .35rem .55rem; border-radius: 6px;
  border: 1px solid var(--border); color: var(--muted); font-weight: 700; font-size: .8rem;
}
.lang-switch:hover { border-color: var(--accent); color: var(--accent); }
.calculator-wide { max-width: 980px; margin: 0 auto; }
.calc-tabs { display: flex; gap: .5rem; margin: 1rem 0 1.25rem; flex-wrap: wrap; }
.calc-tab {
  padding: .55rem 1rem; border-radius: 8px; border: 1px solid var(--border);
  color: var(--muted); background: var(--surface);
}
.calc-tab.active, .calc-tab:hover { border-color: var(--accent); color: var(--accent); }
.craft-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 820px) { .craft-layout { grid-template-columns: 1fr; } }
.craft-panel {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.25rem;
}
.craft-panel h2 { margin: 0 0 1rem; font-size: 1.05rem; }
.item-search-wrap { position: relative; margin-bottom: 1rem; }
.item-search-wrap input { width: 100%; padding: .65rem .75rem; border-radius: 8px; border: 1px solid var(--border); background: #111822; color: var(--text); }
.selected-item { display: flex; gap: .85rem; align-items: center; margin-bottom: 1rem; padding: .75rem; background: #111822; border-radius: 8px; }
.selected-item.hidden { display: none; }
.selected-meta { display: flex; gap: .4rem; margin-top: .35rem; }
.badge { font-size: .75rem; padding: .15rem .45rem; border-radius: 4px; background: #243044; color: var(--muted); }
.recipe-list { list-style: none; margin: 0; padding: 0; }
.recipe-row { display: grid; grid-template-columns: 32px 1fr auto auto; gap: .6rem; align-items: center; padding: .45rem 0; border-bottom: 1px solid var(--border); }
.recipe-row:last-child { border-bottom: none; }
.recipe-name { font-size: .92rem; }
.recipe-qty { color: var(--muted); font-size: .85rem; }
.recipe-price { display: flex; align-items: center; gap: .35rem; }
.recipe-price input, .price-input-wrap input {
  width: 90px; padding: .4rem .5rem; border-radius: 6px;
  border: 1px solid var(--border); background: #111822; color: var(--text);
}
.craft-settings-grid { margin-bottom: .75rem; }
.field-label { display: block; margin: .75rem 0 .35rem; color: var(--muted); font-size: .9rem; }
.qty-row { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.qty-row input[type=number] { width: 90px; padding: .55rem .65rem; border-radius: 8px; border: 1px solid var(--border); background: #111822; color: var(--text); }
.qty-presets { display: flex; gap: .35rem; }
.qty-btn, .pill {
  padding: .45rem .7rem; border-radius: 8px; border: 1px solid var(--border);
  background: #111822; color: var(--text); cursor: pointer;
}
.qty-btn:hover, .pill:hover { border-color: var(--accent); }
.pill.active { background: rgba(201,162,39,.15); border-color: var(--accent); color: var(--accent); }
.pill-group { display: flex; gap: .4rem; flex-wrap: wrap; }
.toggle-row { margin: .85rem 0; }
.toggle { display: flex; align-items: flex-start; gap: .65rem; cursor: pointer; }
.toggle input { display: none; }
.toggle-ui {
  width: 42px; height: 24px; border-radius: 999px; background: #334155; position: relative; flex-shrink: 0;
}
.toggle-ui::after {
  content: ''; position: absolute; top: 3px; left: 3px; width: 18px; height: 18px;
  border-radius: 50%; background: #fff; transition: transform .2s;
}
.toggle input:checked + .toggle-ui { background: var(--accent); }
.toggle input:checked + .toggle-ui::after { transform: translateX(18px); }
.toggle small { display: block; color: var(--muted); font-size: .8rem; margin-top: .15rem; }
.price-input-wrap { display: flex; align-items: center; gap: .5rem; }
.btn-block { width: 100%; margin-top: 1rem; }
.suggestions button.suggestion-item { display: flex; align-items: center; gap: .55rem; }
.profit-title { margin: 1.25rem 0 .75rem; font-size: 1rem; }
.profit-grid .result-card strong.positive { color: var(--success); }
.profit-grid .result-card strong.negative { color: var(--error); }
.profit-card strong { font-size: 1.5rem !important; }
.mat-cell { display: flex; align-items: center; gap: .5rem; }

.specialty-status { padding: .55rem .75rem; border-radius: 8px; font-size: .9rem; margin: .5rem 0; }
.specialty-status.active { background: rgba(62,207,142,.12); color: var(--success); border: 1px solid rgba(62,207,142,.3); }
.specialty-status.inactive { background: rgba(255,107,107,.08); color: var(--muted); border: 1px solid var(--border); }
.specialty-hint { font-size: .85rem; margin: 0 0 .5rem; }
#island_link_wrap.hidden { display: none; }

.craft-panel label.field-block { display: block; margin-bottom: 0; }
.craft-panel select,
.craft-panel .field-block select {
  display: block; width: 100%; margin-top: .35rem;
  padding: .65rem .75rem; border-radius: 8px;
  border: 1px solid var(--border); background: #111822; color: var(--text);
  appearance: auto; cursor: pointer;
}
.craft-panel select option { background: #111822; color: var(--text); }

.results-simple { padding: 0; overflow: hidden; }
.results-simple > *:not(.result-hero) { padding-left: 1.25rem; padding-right: 1.25rem; }
.results-simple .section-title { margin: 1.25rem 0 .35rem; font-size: 1rem; }
.results-simple .result-details,
.results-simple .materials-table-wrap,
.results-simple .rrr-hint { padding-bottom: 1rem; }
.result-hero {
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  padding: 1.5rem 1.25rem; margin-bottom: 1rem;
  background: #111822; border-bottom: 1px solid var(--border);
}
.result-hero.is-profit { border-left: 4px solid var(--success); }
.result-hero.is-loss { border-left: 4px solid var(--error); }
.result-hero-label { display: block; color: var(--muted); font-size: .9rem; margin-bottom: .25rem; }
.result-hero-value { display: block; font-size: 2.2rem; line-height: 1.1; }
.result-hero-value.positive { color: var(--success); }
.result-hero-value.negative { color: var(--error); }
.result-hero-sub { display: block; color: var(--muted); font-size: .85rem; margin-top: .35rem; }
.result-hero-right { text-align: right; display: flex; flex-direction: column; gap: .5rem; align-items: flex-end; }
.verdict-badge {
  padding: .35rem .75rem; border-radius: 999px; font-size: .85rem; font-weight: 700;
}
.verdict-badge.positive { background: rgba(62,207,142,.15); color: var(--success); }
.verdict-badge.negative { background: rgba(255,107,107,.15); color: var(--error); }
.margin-badge { color: var(--muted); font-size: .85rem; }
.result-flow {
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
  padding: 1rem 1.25rem; background: rgba(26,35,50,.6); border-radius: 8px; margin: 0 1.25rem 1rem;
}
.flow-step { flex: 1; min-width: 120px; }
.flow-step span { display: block; color: var(--muted); font-size: .8rem; margin-bottom: .25rem; }
.flow-step strong { font-size: 1.15rem; }
.flow-step small { display: block; color: var(--muted); font-size: .75rem; margin-top: .2rem; }
.flow-step.flow-profit strong.positive { color: var(--success); }
.flow-step.flow-profit strong.negative { color: var(--error); }
.flow-sep { color: var(--muted); font-size: 1.4rem; font-weight: 300; flex-shrink: 0; }
.flow-eq { color: var(--accent); font-weight: 700; }
.rrr-hint { font-size: .85rem; margin: 0 1.25rem .5rem; }
.materials-simple .mat-sub { display: block; color: var(--muted); font-size: .75rem; font-weight: 400; margin-top: .15rem; }
.result-details { margin-top: .5rem; border-top: 1px solid var(--border); padding-top: .75rem; }
.result-details summary {
  cursor: pointer; color: var(--muted); font-size: .9rem; padding: .5rem 0;
  list-style: none;
}
.result-details summary::-webkit-details-marker { display: none; }
.result-details summary::before { content: '▸ '; color: var(--accent); }
.result-details[open] summary::before { content: '▾ '; }
.details-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: .75rem; padding: .75rem 0 1rem;
}
.details-grid div {
  background: #111822; border-radius: 8px; padding: .75rem;
}
.details-grid span { display: block; color: var(--muted); font-size: .8rem; }
.details-grid strong { font-size: 1.1rem; }
@media (max-width: 640px) {
  .result-flow { flex-direction: column; align-items: stretch; }
  .flow-sep { text-align: center; }
  .result-hero { flex-direction: column; align-items: flex-start; }
  .result-hero-right { align-items: flex-start; text-align: left; }
}

.field-hint { font-size: .8rem; margin: .25rem 0 .75rem; }
.flow-step small#r_cost_hint { display: block; color: var(--muted); font-size: .75rem; margin-top: .2rem; }

.refine-conversion {
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
  padding: .75rem; background: #111822; border-radius: 8px;
}
.refine-side { display: flex; align-items: center; gap: .5rem; font-size: .9rem; }
.refine-arrow { color: var(--accent); font-size: 1.2rem; font-weight: 700; }

.market-toolbar {
  display: flex; flex-wrap: wrap; gap: .75rem; align-items: flex-end;
  margin: .75rem 0 1rem; padding: .85rem; background: #111822; border-radius: 8px;
  border: 1px solid var(--border);
}
.market-toolbar .market-price-city { flex: 1 1 180px; margin: 0; }
.market-actions { display: flex; gap: .5rem; flex-wrap: wrap; }
.market-status { width: 100%; margin: 0; font-size: .82rem; }
.market-status.is-success { color: #6ecf8a; }
.market-status.is-error { color: #e07a7a; }
.price-input-wrap input.price-auto { border-color: rgba(110, 207, 138, .45); }
.price-input-wrap input.price-manual,
.recipe-price input.price-manual { border-color: var(--accent); }
.account-card .account-form { margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--border); }
.share-status { width: 100%; margin: 0; font-size: .82rem; }
.share-status.is-success { color: #6ecf8a; }
.share-status.is-error { color: #e07a7a; }

.calc-history-panel {
  margin: 0 0 .75rem; padding: .6rem .75rem;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
}
.calc-history-header { display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.calc-history-header h3 { margin: 0; font-size: .85rem; }
.calc-history-body { margin-top: .5rem; }
.calc-history-body .field-hint { margin: 0 0 .4rem; font-size: .72rem; }
.calc-history-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: .25rem;
  max-height: 11.5rem; overflow-y: auto;
}
.calc-history-item {
  display: flex; align-items: center; gap: .35rem;
  background: #111822; border-radius: 6px; border: 1px solid var(--border);
  min-height: 0;
}
.calc-history-item.is-favorite { border-color: rgba(201, 162, 39, .55); }
.calc-history-link {
  flex: 1; display: flex; align-items: center; gap: .45rem;
  padding: .3rem .45rem; color: inherit; text-decoration: none; min-width: 0;
}
.calc-history-link img { width: 22px; height: 22px; flex-shrink: 0; border-radius: 4px; }
.calc-history-link:hover { background: rgba(255,255,255,.03); border-radius: 6px; }
.calc-history-meta {
  display: flex; align-items: center; justify-content: space-between; gap: .5rem;
  flex: 1; min-width: 0;
}
.calc-history-main { display: flex; flex-direction: column; gap: 0; min-width: 0; flex: 1; }
.calc-history-main strong {
  font-size: .78rem; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.calc-history-main small { color: var(--muted); font-size: .68rem; line-height: 1.2; }
.calc-history-profit {
  font-size: .75rem; font-weight: 700; white-space: nowrap; flex-shrink: 0;
}
.calc-history-profit.positive { color: #6ecf8a; }
.calc-history-profit.negative { color: #e07a7a; }
.calc-history-actions {
  display: flex; flex-direction: row; align-items: center; gap: 0;
  padding-right: .2rem; flex-shrink: 0;
}
.history-star, .history-delete {
  border: none; background: transparent; color: var(--muted);
  cursor: pointer; font-size: .85rem; line-height: 1; padding: .15rem .25rem;
}
.history-star.active { color: var(--accent); }
.history-delete { font-size: 1rem; }
.history-star:hover, .history-delete:hover { color: var(--text); }
.calc-history-empty { margin: .35rem 0 0; font-size: .75rem; }
@media (max-width: 768px) {
  .header-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas: "logo toggle" "nav nav";
    gap: 0 .75rem;
    align-items: center;
  }
  .logo { grid-area: logo; }
  .logo-img { height: 38px !important; }
  .nav-toggle { display: flex; grid-area: toggle; }
  .site-nav {
    grid-area: nav;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100%;
    margin-top: .85rem;
    padding-top: .85rem;
    border-top: 1px solid var(--border);
  }
  .site-nav.is-open { display: flex; }
  .site-nav a {
    padding: .75rem 0;
    border-bottom: 1px solid var(--border);
    color: var(--text);
  }
  .site-nav a:last-child { border-bottom: none; }
  .site-nav .lang-switch {
    align-self: flex-start;
    margin-top: .35rem;
  }
  .site-nav .nav-register {
    width: 100%;
    margin-top: .5rem;
    padding: .7rem 1rem;
  }
  body.nav-open { overflow: hidden; }
  .site-header { z-index: 100; }
}

@media (max-width: 640px) {
  main.container { padding: 1.25rem 0 3rem; }
  .hero { padding: 2rem 0 1.25rem; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions .btn { width: 100%; }
  .calc-tabs { gap: .35rem; }
  .calc-tab { flex: 1 1 calc(50% - .35rem); text-align: center; padding: .55rem .5rem; font-size: .88rem; }
  .market-toolbar { padding: .65rem; }
  .market-actions { width: 100%; }
  .market-actions .btn { flex: 1 1 auto; }
}


.auth-divider { text-align: center; color: var(--muted); margin: 1rem 0; font-size: .9rem; }
.btn-discord {
  display: flex; align-items: center; justify-content: center; gap: .55rem;
  width: 100%; background: #5865F2; color: #fff !important; border: none;
  margin-bottom: .25rem;
}
.btn-discord:hover { background: #4752c4; color: #fff !important; }
.btn-discord-icon { width: 1.15rem; height: 1.15rem; flex-shrink: 0; }

.top-crafts-page h1 { margin: .5rem 0; }
.top-crafts-filters { margin: 1.25rem 0; padding: 1rem; border: 1px solid var(--border); border-radius: 10px; background: rgba(17,24,34,.5); }
.top-crafts-toggles { display: flex; flex-wrap: wrap; gap: 1rem; margin: .75rem 0; }
.checkbox-inline { display: flex; align-items: center; gap: .5rem; font-size: .95rem; }
.tier-range { display: flex; align-items: center; gap: .5rem; }
.tier-range select { flex: 1; }
.top-crafts-actions { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-top: .75rem; }
.top-crafts-meta { margin: .75rem 0 1rem; font-size: .9rem; color: var(--muted); }
.top-crafts-table-wrap { margin-top: 1rem; }
.top-crafts-table .top-rank { color: var(--muted); width: 2rem; }
.top-crafts-table .top-item-cell strong { font-weight: 600; }
.top-crafts-table td.positive strong { color: var(--success); }
.top-crafts-table td.negative strong { color: var(--error); }

.account-section { margin: 1.5rem 0; padding-top: 1rem; border-top: 1px solid var(--border); }
.account-section h2 { margin: 0 0 0.75rem; font-size: 1.05rem; }
.account-actions { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 0.75rem; }
.inline-form { display: inline; }

.pricing-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 960px) {
  .pricing-grid-3 { grid-template-columns: 1fr; }
}
.calc-card-locked { opacity: .85; border-style: dashed; }
.calc-card-locked:hover { border-color: var(--accent); opacity: 1; }

/* Calculators hub v2 */
.calculators-hub-v2 { max-width: 960px; }
.calculators-hub-header { text-align: center; margin-bottom: .5rem; }
.calculators-hub-header h1 { margin-bottom: .35rem; }
.calculators-hub-header .muted { margin: 0; }
.calc-cards-v2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
}
.calc-cards-v2 .calc-card {
  display: flex;
  flex-direction: column;
  min-height: 220px;
  padding: 1.35rem 1.4rem 1.2rem;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.calc-cards-v2 .calc-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, .22);
}
.calc-card-icon-wrap {
  position: relative;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  background: rgba(212, 175, 55, .1);
  color: var(--accent);
  flex-shrink: 0;
}
.calc-card-icon-wrap svg { width: 1.65rem; height: 1.65rem; }
.calc-card-icon-craft { background: rgba(212, 175, 55, .14); color: #e8c547; }
.calc-card-icon-refine { background: rgba(96, 165, 250, .12); color: #7cb8ff; }
.calc-card-icon-farm { background: rgba(62, 207, 142, .12); color: #5fd99a; }
.calc-card-icon-top { background: rgba(212, 175, 55, .16); color: var(--accent); }
.calc-cards-v2 .calc-card h2 { font-size: 1.15rem; line-height: 1.25; }
.calc-cards-v2 .calc-card p {
  flex: 1;
  line-height: 1.45;
  margin-top: .35rem;
}
.calc-cards-v2 .calc-card-cta {
  margin-top: auto;
  padding-top: 1rem;
  display: inline-flex;
  align-items: center;
  gap: .25rem;
}
.calc-card-lock {
  position: absolute;
  right: -.35rem;
  bottom: -.35rem;
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
}
.calc-card-lock svg { width: .75rem; height: .75rem; }
.calc-card-locked .calc-card-icon-wrap { opacity: .75; }
@media (max-width: 700px) {
  .calc-cards-v2 { grid-template-columns: 1fr; }
  .calc-cards-v2 .calc-card { min-height: 0; }
}
