/* FrezPilot — Global Styles
   Imports Google Fonts + uses CSS variables from the active theme */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@300;400;600;700;800&family=Barlow:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; }

body {
  font-family: var(--fp-font-body);
  background: var(--fp-bg-base);
  color: var(--fp-text);
  min-height: 100vh;
  line-height: 1.6;
}

/* ---- LAYOUT ---- */
.fp-wrap      { max-width: 1280px; margin: 0 auto; padding: 0 20px; }
.fp-main      { min-height: calc(100vh - var(--fp-header-height) - 80px); }

/* ---- HEADER ---- */
.fp-header {
  background: var(--fp-header-bg);
  border-bottom: 2px solid var(--fp-header-border);
  height: var(--fp-header-height);
  position: sticky; top: 0; z-index: 100;
  box-shadow: 0 2px 16px rgba(0,0,0,.4);
}
.fp-header-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 100%;
  gap: 12px;
}
.fp-header-left  { display: flex; align-items: center; gap: 8px; }
.fp-header-center { display: flex; justify-content: center; align-items: center; }
.fp-header-right { display: flex; align-items: center; justify-content: flex-end; gap: 12px; }

.fp-logo { display: flex; align-items: center; text-decoration: none; }
.fp-logo img, .fp-logo svg { height: 44px; width: auto; }

/* Plugin nav icons under header logo */
.fp-plugin-nav {
  display: flex; align-items: center; gap: 6px;
  flex-wrap: wrap;
}
.fp-plugin-nav a {
  display: flex; flex-direction: column; align-items: center;
  text-decoration: none; color: var(--fp-text-muted);
  font-size: 11px; font-weight: 500;
  padding: 4px 10px; border-radius: var(--fp-radius-sm);
  transition: all .18s;
  gap: 3px;
  border: 1px solid transparent;
}
.fp-plugin-nav a:hover, .fp-plugin-nav a.active {
  color: var(--fp-primary);
  background: rgba(249,115,22,.08);
  border-color: rgba(249,115,22,.25);
}
.fp-plugin-nav .pn-icon { font-size: 18px; line-height: 1; }
.fp-plugin-nav .pn-badge {
  font-size: 9px; font-weight: 700; line-height: 1;
  padding: 1px 5px; border-radius: 3px;
  text-transform: uppercase; letter-spacing: .4px;
}
.pn-badge-pro  { background: rgba(249,115,22,.18); color: var(--fp-primary); }
.pn-badge-free { background: rgba(59,130,246,.15);  color: #60a5fa; }

/* ---- USER AREA ---- */
.fp-user-area { position: relative; display: flex; align-items: center; gap: 10px; }
.fp-user-btn {
  display: flex; align-items: center; gap: 8px;
  background: var(--fp-bg-card); border: 1px solid var(--fp-border);
  border-radius: 50px; padding: 4px 14px 4px 4px;
  cursor: pointer; text-decoration: none; color: var(--fp-text);
  transition: all .18s; font-size: 14px;
}
.fp-user-btn:hover { border-color: var(--fp-primary); background: var(--fp-bg-hover); }
.fp-user-avatar {
  width: 34px; height: 34px; border-radius: 50%;
  object-fit: cover; background: var(--fp-bg-hover);
  border: 2px solid var(--fp-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; color: var(--fp-primary);
  overflow: hidden;
}
.fp-user-avatar img { width: 100%; height: 100%; object-fit: cover; }
.fp-plan-badge {
  font-size: 10px; font-weight: 700; padding: 2px 6px;
  border-radius: 4px; text-transform: uppercase; letter-spacing: .5px;
}
.fp-plan-badge.free  { background: rgba(100,116,139,.2); color: #94a3b8; }
.fp-plan-badge.paid  { background: rgba(249,115,22,.15); color: #f97316; }
.fp-plan-badge.edu   { background: rgba(59,130,246,.15); color: #3b82f6; }

/* Dropdown */
.fp-dropdown { position: relative; }
.fp-dropdown-menu {
  position: absolute; top: 100%; right: 0;
  /* padding-top bridges the visual gap so hover never breaks */
  padding-top: 6px;
  background: transparent;
  min-width: 190px;
  z-index: 200;
  display: none;
}
/* Inner card holds the actual visual styling */
.fp-dropdown-menu-inner {
  background: var(--fp-bg-card); border: 1px solid var(--fp-border);
  border-radius: var(--fp-radius);
  box-shadow: var(--fp-shadow);
  overflow: hidden;
}
.fp-dropdown:hover .fp-dropdown-menu,
.fp-dropdown.open .fp-dropdown-menu { display: block; }
.fp-dropdown-menu a, .fp-dropdown-menu button {
  display: block; width: 100%; padding: 10px 16px;
  color: var(--fp-text); text-decoration: none; font-size: 14px;
  background: none; border: none; text-align: left; cursor: pointer;
  transition: background .15s;
}
.fp-dropdown-menu a:hover, .fp-dropdown-menu button:hover {
  background: var(--fp-bg-hover); color: var(--fp-primary);
}
.fp-dropdown-menu hr { border: none; border-top: 1px solid var(--fp-border); margin: 4px 0; }

/* ---- LANGUAGE FLAGS ---- */
.fp-lang-switcher { display: flex; align-items: center; gap: 5px; }
.fp-lang-flag {
  width: 28px; height: 19px; border-radius: 3px; overflow: hidden;
  cursor: pointer; opacity: .55; transition: opacity .15s, transform .15s;
  border: 1px solid transparent; display: block;
}
.fp-lang-flag:hover, .fp-lang-flag.active {
  opacity: 1; transform: scale(1.1); border-color: var(--fp-primary);
}
.fp-lang-flag img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---- CARDS ---- */
.fp-card {
  background: var(--fp-bg-card); border: 1px solid var(--fp-border);
  border-radius: var(--fp-radius-lg); padding: 24px;
  box-shadow: var(--fp-shadow-card);
}
.fp-card-title { font-family: var(--fp-font-display); font-size: 1.3rem; font-weight: 700; color: var(--fp-text); margin-bottom: 16px; }

/* ---- FORMS ---- */
.fp-form-group { margin-bottom: 18px; }
.fp-label {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 500; color: var(--fp-text-muted);
  margin-bottom: 6px;
}
.fp-input, .fp-select, .fp-textarea {
  width: 100%; padding: 10px 14px;
  background: var(--fp-bg-input); border: 1px solid var(--fp-border);
  border-radius: var(--fp-radius); color: var(--fp-text); font-size: 15px;
  font-family: var(--fp-font-body); transition: border-color .18s;
  appearance: none;
}
.fp-input:focus, .fp-select:focus, .fp-textarea:focus {
  outline: none; border-color: var(--fp-border-focus);
  box-shadow: 0 0 0 3px rgba(249,115,22,.15);
}
.fp-select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 36px; }
.fp-textarea { min-height: 100px; resize: vertical; }
.fp-input-help { display: inline-flex; align-items: center; justify-content: center; width: 16px; height: 16px; border-radius: 50%; background: var(--fp-border); color: var(--fp-text-muted); font-size: 10px; cursor: help; flex-shrink: 0; }

/* ---- BUTTONS ---- */
.fp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 10px 22px; border-radius: var(--fp-radius); font-size: 15px;
  font-family: var(--fp-font-body); font-weight: 600;
  cursor: pointer; border: none; transition: all .18s; text-decoration: none;
  letter-spacing: .2px;
}
.fp-btn-primary { background: var(--fp-primary); color: #fff; }
.fp-btn-primary:hover { background: var(--fp-primary-dark); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(249,115,22,.3); }
.fp-btn-secondary { background: var(--fp-bg-card); color: var(--fp-text); border: 1px solid var(--fp-border); }
.fp-btn-secondary:hover { border-color: var(--fp-primary); color: var(--fp-primary); }
.fp-btn-danger { background: var(--fp-error); color: #fff; }
.fp-btn-danger:hover { background: #dc2626; }
.fp-btn-sm { padding: 6px 14px; font-size: 13px; }
.fp-btn-lg { padding: 13px 30px; font-size: 17px; }
.fp-btn:disabled { opacity: .5; cursor: not-allowed; transform: none !important; }
.fp-btn-block { width: 100%; }

/* ---- ALERTS ---- */
.fp-alert { padding: 12px 16px; border-radius: var(--fp-radius); font-size: 14px; margin-bottom: 16px; display: flex; align-items: flex-start; gap: 10px; }
.fp-alert-success { background: var(--fp-success-bg); color: #86efac; border: 1px solid #166534; }
.fp-alert-error   { background: var(--fp-error-bg);   color: #fca5a5; border: 1px solid #7f1d1d; }
.fp-alert-warning { background: var(--fp-warning-bg); color: #fcd34d; border: 1px solid #78350f; }
.fp-alert-info    { background: var(--fp-info-bg);    color: #7dd3fc; border: 1px solid #0c4a6e; }

/* ---- TABLES ---- */
.fp-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.fp-table th { background: var(--fp-bg-surface); color: var(--fp-text-muted); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .8px; padding: 10px 14px; text-align: left; border-bottom: 1px solid var(--fp-border); }
.fp-table td { padding: 11px 14px; border-bottom: 1px solid rgba(30,58,95,.5); color: var(--fp-text); vertical-align: middle; }
.fp-table tr:hover td { background: var(--fp-bg-hover); }
.fp-table-wrap { overflow-x: auto; border-radius: var(--fp-radius); border: 1px solid var(--fp-border); }

/* ---- BADGES ---- */
.fp-badge { display: inline-block; font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 50px; text-transform: uppercase; letter-spacing: .4px; }
.fp-badge-orange { background: rgba(249,115,22,.15); color: #f97316; }
.fp-badge-blue   { background: rgba(59,130,246,.15); color: #60a5fa; }
.fp-badge-green  { background: rgba(34,197,94,.15);  color: #4ade80; }
.fp-badge-gray   { background: rgba(100,116,139,.15);color: #94a3b8; }
.fp-badge-red    { background: rgba(239,68,68,.15);  color: #f87171; }

/* ---- TOOLTIPS ---- */
[data-tooltip] { position: relative; cursor: help; }
[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute; bottom: calc(100% + 6px); left: 50%; transform: translateX(-50%);
  background: #0d1826; color: #e2e8f0; padding: 6px 10px;
  border-radius: 6px; font-size: 12px; white-space: nowrap; z-index: 300;
  border: 1px solid var(--fp-border); pointer-events: none;
  opacity: 0; transition: opacity .15s;
  max-width: 240px; white-space: normal; text-align: center;
}
[data-tooltip]:hover::after { opacity: 1; }

/* ---- RESULT BOX ---- */
.fp-result-box {
  background: linear-gradient(135deg, rgba(249,115,22,.06) 0%, rgba(249,115,22,.02) 100%);
  border: 1px solid rgba(249,115,22,.25);
  border-radius: var(--fp-radius-lg); padding: 20px 24px;
  margin-top: 20px;
}
.fp-result-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 16px; }
.fp-result-item { text-align: center; }
.fp-result-value { font-family: var(--fp-font-display); font-size: 2rem; font-weight: 700; color: var(--fp-primary); line-height: 1; }
.fp-result-unit  { font-size: 12px; color: var(--fp-text-muted); margin-top: 2px; }
.fp-result-label { font-size: 13px; color: var(--fp-text-faint); margin-top: 4px; }

/* ---- TABS ---- */
.fp-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--fp-border); margin-bottom: 20px; }
.fp-tab { padding: 9px 18px; font-size: 14px; font-weight: 500; color: var(--fp-text-muted); cursor: pointer; border-bottom: 2px solid transparent; transition: all .15s; background: none; border-top: none; border-left: none; border-right: none; }
.fp-tab:hover { color: var(--fp-text); }
.fp-tab.active { color: var(--fp-primary); border-bottom-color: var(--fp-primary); }

/* ---- GRID LAYOUTS ---- */
.fp-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.fp-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.fp-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 900px) { .fp-grid-3, .fp-grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .fp-grid-2, .fp-grid-3, .fp-grid-4 { grid-template-columns: 1fr; } }

/* ---- PAGE LAYOUT ---- */
.fp-page-header { padding: 28px 0 20px; }
.fp-page-title  { font-family: var(--fp-font-display); font-size: 2rem; font-weight: 700; color: var(--fp-text); line-height: 1.2; }
.fp-page-subtitle { font-size: 15px; color: var(--fp-text-muted); margin-top: 4px; }

/* ---- FOOTER ---- */
.fp-footer {
  background: var(--fp-bg-surface); border-top: 1px solid var(--fp-border);
  padding: 24px 0; margin-top: auto;
}
.fp-footer-inner {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; font-size: 13px; color: var(--fp-text-faint);
}
.fp-footer a { color: var(--fp-text-muted); text-decoration: none; transition: color .15s; }
.fp-footer a:hover { color: var(--fp-primary); }
.fp-footer-links { display: flex; gap: 16px; flex-wrap: wrap; }

/* ---- COOKIE BANNER ---- */
.fp-cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 500;
  background: var(--fp-bg-card); border-top: 2px solid var(--fp-border);
  padding: 14px 20px; display: flex; align-items: center;
  justify-content: space-between; gap: 16px; flex-wrap: wrap;
  box-shadow: 0 -4px 20px rgba(0,0,0,.4);
}
.fp-cookie-banner p { font-size: 13px; color: var(--fp-text-muted); flex: 1; }
.fp-cookie-banner a { color: var(--fp-primary); }
.fp-cookie-actions { display: flex; gap: 8px; flex-shrink: 0; }

/* ---- ADMIN SIDEBAR ---- */
.fp-admin-layout { display: flex; min-height: calc(100vh - var(--fp-header-height)); }
.fp-admin-sidebar {
  width: var(--fp-sidebar-width); background: var(--fp-sidebar-bg);
  border-right: 1px solid var(--fp-border); padding: 20px 0;
  flex-shrink: 0;
}
.fp-admin-sidebar a {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 20px; font-size: 14px; color: var(--fp-text-muted);
  text-decoration: none; transition: all .15s; border-left: 3px solid transparent;
}
.fp-admin-sidebar a:hover, .fp-admin-sidebar a.active {
  color: var(--fp-primary); background: rgba(249,115,22,.06);
  border-left-color: var(--fp-primary);
}
.fp-admin-content { flex: 1; padding: 28px; overflow-x: auto; }

/* ---- MODAL ---- */
.fp-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.7); z-index: 400;
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.fp-modal {
  background: var(--fp-bg-card); border: 1px solid var(--fp-border);
  border-radius: var(--fp-radius-lg); width: 100%; max-width: 520px;
  box-shadow: var(--fp-shadow); padding: 28px;
}
.fp-modal-title { font-family: var(--fp-font-display); font-size: 1.3rem; font-weight: 700; margin-bottom: 16px; }

/* ---- TOGGLE / SWITCH ---- */
.fp-toggle { position: relative; display: inline-block; width: 44px; height: 24px; }
.fp-toggle input { opacity: 0; width: 0; height: 0; }
.fp-toggle-slider {
  position: absolute; cursor: pointer; inset: 0;
  background: var(--fp-border); border-radius: 24px; transition: .2s;
}
.fp-toggle-slider::before {
  content: ''; position: absolute; height: 18px; width: 18px;
  left: 3px; bottom: 3px; background: white; border-radius: 50%; transition: .2s;
}
.fp-toggle input:checked + .fp-toggle-slider { background: var(--fp-primary); }
.fp-toggle input:checked + .fp-toggle-slider::before { transform: translateX(20px); }

/* ---- SCROLLBAR ---- */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--fp-bg-base); }
::-webkit-scrollbar-thumb { background: var(--fp-border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--fp-primary); }

/* ---- UTILITIES ---- */
.mt-0 { margin-top: 0; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-3 { margin-top: 24px; }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 16px; }
.mb-3 { margin-bottom: 24px; }
.text-muted  { color: var(--fp-text-muted); }
.text-center { text-align: center; }
.text-right  { text-align: right; }
.text-primary{ color: var(--fp-primary); }
.text-small  { font-size: 13px; }
.flex        { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.gap-1       { gap: 8px; }
.gap-2       { gap: 16px; }
.d-none      { display: none !important; }
.w-100       { width: 100%; }

/* ============================================================
   RESPONSIVE DESIGN — full mobile/tablet overhaul
   Breakpoints: 1024px (tablet), 768px (mobile), 480px (small mobile)
   ============================================================ */

/* ---- Tablet (≤1024px) ---- */
@media (max-width: 1024px) {
  .fp-grid-3, .fp-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .fp-admin-sidebar { width: 200px; }
  .fp-admin-sidebar .sidebar-label { display: none; }
  .fp-admin-sidebar a { font-size: 12px; padding: 9px 14px; }
}

/* ---- Mobile (≤768px) ---- */
@media (max-width: 768px) {

  /* HEADER — stack into 2 rows */
  .fp-header { height: auto; min-height: var(--fp-header-height); }
  .fp-header-inner {
    grid-template-columns: 1fr auto !important;
    grid-template-rows: auto auto;
    padding: 8px 0;
    gap: 6px;
    height: auto !important;
  }
  .fp-header-center {
    grid-column: 1; grid-row: 1;
    justify-content: flex-start;
  }
  .fp-header-center img { height: 34px; }
  .fp-header-right {
    grid-column: 2; grid-row: 1;
    gap: 6px;
  }
  .fp-header-left {
    grid-column: 1 / -1; grid-row: 2;
    overflow-x: auto; -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }
  .fp-plugin-nav {
    display: flex !important;
    flex-wrap: nowrap;
    gap: 4px;
    white-space: nowrap;
  }
  .fp-plugin-nav a {
    font-size: 10px;
    padding: 3px 8px;
    flex-shrink: 0;
  }
  .fp-plugin-nav .pn-icon { font-size: 14px; }

  /* LANGUAGE FLAGS — smaller, no overflow */
  .fp-lang-switcher { gap: 3px; }
  .fp-lang-flag { width: 22px; height: 15px; }

  /* USER BUTTON — compact */
  .fp-user-btn { padding: 3px 8px 3px 3px; font-size: 12px; }
  .fp-user-avatar { width: 28px; height: 28px; font-size: 11px; }
  .fp-user-btn > span:first-of-type { display: none; } /* hide name, keep badge */
  .fp-plan-badge { font-size: 9px; padding: 1px 5px; }

  /* MAIN CONTENT */
  .fp-wrap { padding: 0 12px; }
  .fp-main { min-height: calc(100vh - 100px); }

  /* GRIDS — all single column on mobile */
  .fp-grid-2, .fp-grid-3, .fp-grid-4 { grid-template-columns: 1fr !important; }

  /* CARDS */
  .fp-card { padding: 16px; }

  /* TABLES — horizontal scroll */
  .fp-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .fp-table { min-width: 500px; font-size: 12px; }
  .fp-table th, .fp-table td { padding: 8px 10px; white-space: nowrap; }
  /* Allow wrapping for description/notes columns */
  .fp-table td:first-child { white-space: normal; min-width: 120px; }

  /* BUTTONS — full width on small screens in forms */
  .fp-btn-block { width: 100%; }

  /* ADMIN LAYOUT — sidebar hidden, content full width */
  .fp-admin-layout { flex-direction: column; }
  .fp-admin-sidebar { display: none; }
  .fp-admin-content { padding: 14px; width: 100%; max-width: 100%; }

  /* ADMIN — mobile nav menu */
  .fp-admin-mobile-nav {
    display: flex !important;
    overflow-x: auto;
    gap: 4px;
    padding: 8px 0 12px;
    border-bottom: 1px solid var(--fp-border);
    margin-bottom: 16px;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
  .fp-admin-mobile-nav a {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    font-size: 12px;
    border-radius: var(--fp-radius-sm);
    text-decoration: none;
    color: var(--fp-text-muted);
    border: 1px solid var(--fp-border);
    background: var(--fp-bg-surface);
    flex-shrink: 0;
    white-space: nowrap;
  }
  .fp-admin-mobile-nav a.active,
  .fp-admin-mobile-nav a:hover {
    color: var(--fp-primary);
    border-color: var(--fp-primary);
    background: rgba(249,115,22,.08);
  }

  /* DASHBOARD — calc grid single col */
  .fp-calc-grid { grid-template-columns: 1fr !important; }

  /* RESULT BOX */
  .fp-result-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* MODAL */
  .fp-modal { padding: 18px; margin: 12px; }

  /* TABS — scrollable */
  .fp-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap; flex-wrap: nowrap; }
  .fp-tab { flex-shrink: 0; padding: 8px 12px; font-size: 13px; }

  /* FOOTER */
  .fp-footer-inner { flex-direction: column; align-items: flex-start; gap: 8px; }
  .fp-footer-links { flex-wrap: wrap; gap: 10px; }

  /* COOKIE BANNER */
  .fp-cookie-banner { flex-direction: column; gap: 10px; padding: 14px; }
  .fp-cookie-actions { width: 100%; justify-content: flex-end; }

  /* PAGE HEADER */
  .fp-page-title { font-size: 1.6rem; }

  /* WELDING CALC — thickness row */
  .thickness-row { grid-template-columns: 1fr 1fr !important; gap: 8px; }

  /* PLUGIN NAV actions — wrap properly */
  .fp-plugin-actions { flex-wrap: wrap; gap: 6px; }

  /* PRICING GRID — single col */
  .fp-pricing-grid { grid-template-columns: 1fr !important; }
}

/* ---- Small mobile (≤480px) ---- */
@media (max-width: 480px) {
  .fp-header-right .fp-btn { display: none; } /* hide login/register text buttons, keep user dropdown */
  .fp-header-right .fp-dropdown { display: flex; }

  /* Show short login link instead */
  .fp-header-login-mobile { display: flex !important; }

  .fp-user-btn > .fp-plan-badge { display: none; }

  .fp-lang-flag { width: 20px; height: 13px; }
  .fp-lang-switcher { gap: 2px; }

  .fp-result-grid { grid-template-columns: 1fr 1fr !important; }

  /* Admin table action buttons */
  .fp-table td:last-child { white-space: normal; }
  .fp-table .fp-btn { font-size: 11px; padding: 4px 8px; }

  .fp-card { padding: 12px; }
  .fp-card-title { font-size: 1.1rem; }

  /* Welding proc buttons — 2 per row */
  .weld-proc-btn { min-width: 70px; padding: 8px 10px; font-size: 11px; }
  .weld-proc-btn .proc-icon { font-size: 1.4rem; }

  /* Result big number */
  .weld-amps-val { font-size: 3rem !important; }
}


/* ---- Shared calculator result styles (used in dashboard + plugins) ---- */
.coolant-box {
  background: var(--fp-info-bg); border: 1px solid #0c4a6e;
  border-radius: var(--fp-radius); padding: 8px 12px;
  font-size: 13px; color: var(--fp-info); margin-top: 8px;
}
.warning-box {
  background: var(--fp-warning-bg); border: 1px solid #78350f;
  border-radius: var(--fp-radius); padding: 8px 12px;
  font-size: 13px; color: var(--fp-warning); margin-top: 6px;
}
.result-note {
  background: var(--fp-bg-surface); border: 1px solid var(--fp-border);
  border-radius: var(--fp-radius); padding: 8px 12px;
  font-size: 13px; color: var(--fp-text-muted); margin-top: 6px;
}
.param-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 5px 0; border-bottom: 1px solid rgba(30,58,95,.35);
}
.param-row:last-child { border: none; }
.param-name  { color: var(--fp-text-muted); font-size: 13px; }
.param-val   { font-family: var(--fp-font-display); font-size: 1.1rem; font-weight: 700; color: var(--fp-text); }
.param-unit  { font-size: 11px; color: var(--fp-text-faint); margin-left: 4px; }
.param-range { font-size: 11px; color: var(--fp-text-faint); margin-left: 8px; }
.coolant-warn {
  background: var(--fp-warning-bg); border: 1px solid #78350f;
  border-radius: var(--fp-radius); padding: 7px 12px;
  font-size: 12px; color: var(--fp-warning); margin-top: 6px;
}
.mt-1 { margin-top: 6px; }
.mt-2 { margin-top: 12px; }
