/* /tools/fuel-cost-calculator/style.css
   Production-ready, fully scoped to .tool-card (and adjacent seo-section)
   Keep changes minimal so existing JS/HTML fortsently works.
*/

/* -------------------------
   Core tool card (yours)
   ------------------------- */
.tool-card{
  --card:#ffffff;
  --accent:#0f62fe;
  --muted:#566575;
  --border:#e6eefc;
  --shadow-1:0 6px 18px rgba(12,30,80,0.06);
  --shadow-2:0 8px 30px rgba(12,30,80,0.06);
  --maxw:980px;
  box-sizing:border-box;
  width:100%;
  max-width:var(--maxw);
  margin:22px auto;
  background:var(--card);
  padding:20px 20px 14px;
  border-radius:12px;
  box-shadow:var(--shadow-2);
  border:1px solid rgba(12,30,80,0.03);
  position:relative;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Headings */
.tool-card h1{margin:0 0 8px;font-size:28px;line-height:1.05;color:#0b1620;font-weight:700}
.tool-card .subtitle{margin:0 0 18px;color:var(--muted);font-size:14px}

/* Form grid */
.tool-card .form-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:start}
@media (min-width:1100px){.tool-card .form-grid{grid-template-columns:repeat(4,1fr) 220px}}

/* Labels + inputs */
.tool-card label{display:flex;flex-direction:column;font-size:13px;color:var(--muted)}
.tool-card input[type="number"],.tool-card input[type="search"],.tool-card input[type="text"],.tool-card select,
.tool-card .selected-option{padding:10px;margin-top:6px;border-radius:8px;border:1px solid var(--border);background:#fff;font-size:14px;outline:none;transition:box-shadow .12s,border-color .12s;width:100%;box-sizing:border-box;color:#0f1724;min-height:42px}
.tool-card input::placeholder{color:#cbd5e1}
.tool-card input:focus,.tool-card select:focus,.tool-card .dropdown-search:focus{box-shadow:0 4px 12px rgba(12,30,80,0.06);border-color:rgba(15,98,254,0.25)}

/* Actions / buttons */
.tool-card .actions{margin-top:12px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.tool-card button{padding:10px 14px;border-radius:8px;border:none;cursor:pointer;background:var(--accent);color:#fff;font-weight:600;box-shadow:var(--shadow-1);font-size:14px;transition:transform .12s,box-shadow .12s}
.tool-card button.muted{background:#eef2ff;color:var(--accent);border:1px solid rgba(210,220,255,0.6);box-shadow:none;padding:8px 12px;font-size:14px}
.tool-card button#shareBtn{background:transparent;color:var(--accent);border:1px solid rgba(11,99,255,0.12);padding:7px 10px;border-radius:6px;font-size:13px}
.tool-card button:focus,.tool-card button:hover{outline:none;transform:translateY(-1px);box-shadow:0 10px 22px rgba(12,30,80,0.06)}
/* better keyboard focus */
.tool-card button:focus-visible{outline:3px solid rgba(15,98,254,0.12);outline-offset:2px}

/* Result / legacy-compatible */
.tool-card .result,.tool-card .result-card{margin-top:14px;padding:18px;border-radius:10px;background:#fcfdff;border:1px solid var(--border);font-size:15px;color:#0f172a;line-height:1.45;overflow:hidden;box-shadow:0 2px 8px rgba(15,23,42,0.03)}
.tool-card .result strong,.tool-card .result-card strong{font-size:15px}

/* Result grid (if used) */
.tool-card .result-grid{display:grid;grid-template-columns:1fr 240px;gap:18px;align-items:start}
@media (max-width:780px){.tool-card .result-grid{grid-template-columns:1fr}}

/* Stat / small lines */
.tool-card .stat-line{display:flex;justify-content:space-between;gap:12px;align-items:baseline;margin:6px 0}
.tool-card .stat-line .label{flex:1 1 auto;color:#374151;font-weight:600;min-width:0}
.tool-card .stat-line .value{flex:0 0 auto;color:#111827;font-weight:800;text-align:right;min-width:90px}

/* Conversion hint */
.tool-card .conversion-hint{color:var(--muted);font-size:13px;margin-top:6px}

/* Per-person box (legacy + new) */
.tool-card .per-person-box{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid #e6eef9;border-radius:10px;padding:14px 16px;width:100%;box-shadow:0 1px 0 rgba(11,99,255,0.04);text-align:right}
.tool-card .per-person-box .label{font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:600}
.tool-card .per-person-box .amount{font-size:18px;font-weight:800;color:var(--accent)}

/* Currency dropdown */
.tool-card .currency-dropdown{position:relative;margin-top:6px}
.tool-card .selected-option{display:flex;align-items:center;gap:8px;min-height:44px;cursor:pointer}
.tool-card .selected-option img.flag{width:22px;height:14px;object-fit:cover;border:1px solid rgba(0,0,0,0.06);display:inline-block}
.tool-card .dropdown-list{position:absolute;top:52px;right:0;width:280px;max-height:420px;overflow:auto;background:var(--card);border:1px solid var(--border);border-radius:8px;z-index:120;padding:6px;box-shadow:0 12px 30px rgba(12,30,80,0.08)}
@media (max-width:720px){.tool-card .dropdown-list{left:0;right:0;top:68px;width:auto;max-height:220px}}
.tool-card .hidden{display:none!important}
.tool-card .dropdown-search-wrap{padding:6px 8px;border-bottom:1px solid #f0f4ff}
.tool-card .dropdown-search{width:100%;padding:8px 10px;border-radius:6px;border:1px solid #e6eefc;font-size:14px;box-sizing:border-box;color:#0f1724}
.tool-card .dropdown-items{max-height:200px;overflow:auto}
.tool-card .dropdown-item{padding:8px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;border-radius:6px;white-space:nowrap;color:#0f1724;font-size:14px}
.tool-card .dropdown-item:hover,.tool-card .dropdown-item:focus{background:#eef3ff;outline:none}
.tool-card .no-results{font-size:14px;color:#666;padding:8px 12px}
.tool-card .dropdown-item img.flag{width:22px;height:14px;object-fit:cover;border:1px solid rgba(0,0,0,0.06);flex-shrink:0}

/* Scrollbar (scoped) */
.tool-card .dropdown-list::-webkit-scrollbar,.tool-card .dropdown-items::-webkit-scrollbar{height:10px;width:10px}
.tool-card .dropdown-list::-webkit-scrollbar-thumb,.tool-card .dropdown-items::-webkit-scrollbar-thumb{background:rgba(12,30,80,0.12);border-radius:6px}

/* Accessibility */
.tool-card .dropdown-item:focus{outline:2px solid rgba(15,98,254,0.12);outline-offset:2px}
.tool-card .visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap;border:0;padding:0;margin:-1px}

/* Label tip (tooltip) */
.tool-card .label-with-tip{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:13px;color:var(--muted);width:100%;box-sizing:border-box}
.tool-card .label-with-tip>span{flex:1 1 auto;min-width:0}
.tool-card .label-tip{flex:0 0 auto;width:18px;height:18px;border-radius:50%;background:#eef3ff;color:var(--accent);font-size:11px;line-height:18px;text-align:center;cursor:default;position:relative;border:1px solid rgba(15,98,254,0.12);display:inline-flex;align-items:center;justify-content:center;margin-left:8px;margin-right:2px}
.tool-card .label-tip .bubble{position:absolute;bottom:calc(100% + 8px);right:0;background:#0f1724;color:#fff;padding:8px 10px;border-radius:6px;font-size:13px;line-height:1.3;min-width:160px;max-width:260px;box-shadow:0 6px 18px rgba(0,0,0,0.15);opacity:0;pointer-events:none;transition:opacity .12s,transform .12s;z-index:200;transform-origin:right center}
.tool-card .label-tip .bubble::after{content:"";position:absolute;top:100%;right:10px;border:6px solid transparent;border-top-color:#0f1724}
.tool-card .label-tip:hover .bubble,.tool-card .label-tip:focus-within .bubble{opacity:1;pointer-events:auto;transform:translateY(-4px)}
@media (max-width:520px){.tool-card .label-tip .bubble{left:0!important;right:0!important;transform:none;bottom:calc(100% + 8px);margin:0 auto;max-width:none}.tool-card .label-with-tip{gap:6px}}

/* fuel-result-card (modern component) */
.tool-card .fuel-result-card{font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;max-width:980px;margin:18px auto 8px;background:linear-gradient(180deg,rgba(255,255,255,0.95),rgba(250,250,252,0.95));border-radius:14px;box-shadow:0 8px 30px rgba(15,23,42,0.08);padding:18px;color:#0b1620;backdrop-filter:blur(6px);border:1px solid rgba(15,23,42,0.04);transition:transform .2s,box-shadow .2s}
.tool-card .fuel-result-card.show{transform:translateY(0);box-shadow:0 18px 40px rgba(15,23,42,0.12)}
.tool-card .fuel-result-card .fr-top{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start;overflow:visible}
@media (max-width:880px){.tool-card .fuel-result-card .fr-top{grid-template-columns:1fr}.tool-card .fuel-result-card .fr-right{align-items:flex-start}}
.tool-card .fuel-result-card .kpi-label{color:#6b7280;font-size:13px;margin-bottom:6px}
.tool-card .fuel-result-card .kpi-value{font-size:34px;font-weight:700;letter-spacing:-0.02em;margin-bottom:4px;color:#0b1620}
.tool-card .fuel-result-card .kpi-sub{color:#6b7280;font-size:13px}
.tool-card .fuel-result-card .fr-meta{margin-top:10px;color:#475569;font-size:13px}
.tool-card .fuel-result-card .fr-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.tool-card .fuel-result-card .per-person{text-align:right;background:rgba(15,99,255,0.06);padding:10px 14px;border-radius:10px;min-width:200px}
.tool-card .fuel-result-card .pp-label{color:#374151;font-size:12px}
.tool-card .fuel-result-card .pp-value{font-size:20px;font-weight:600;margin-top:6px;color:#0b1620}
.tool-card .fuel-result-card .pp-sub{font-size:12px;color:#6b7280;margin-top:4px}

/* result buttons */
.tool-card .fuel-result-card .btn{border:0;padding:8px 12px;border-radius:8px;font-size:13px;cursor:pointer;min-height:38px;display:inline-flex;align-items:center;justify-content:center;line-height:1;transition:transform .12s,box-shadow .12s;color:#0b1620;background:#fff;border:1px solid rgba(15,23,42,0.06)}
.tool-card .fuel-result-card .btn.ghost{background:#f8fafc;color:#0b1620}
.tool-card .fuel-result-card .btn.primary{background:var(--accent);color:#fff;box-shadow:0 6px 18px rgba(15,98,254,0.15);border:none}
.tool-card .fuel-result-card .btn:hover,.tool-card .fuel-result-card .btn:focus{transform:translateY(-1px);box-shadow:0 8px 18px rgba(15,23,42,0.06);outline:none}

/* details toggle + breakdown */
.tool-card .fuel-result-card .details-toggle{margin-top:14px;width:100%;background:#eef3ff;border:0;color:#0f1724;font-weight:600;text-align:left;padding:10px;cursor:pointer;position:relative;z-index:30;-webkit-tap-highlight-color:transparent}
.tool-card .fuel-result-card .fr-breakdown{margin-top:10px;padding-top:14px;border-top:1px dashed rgba(15,23,42,0.04);transition:max-height .28s,opacity .18s;opacity:1;max-height:1600px;overflow:hidden}
.tool-card .fuel-result-card .fr-breakdown[hidden]{display:block;opacity:0;max-height:0 !important;padding-top:0 !important;border-top:0 !important;pointer-events:none}
.tool-card .fuel-result-card .break-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.tool-card .fuel-result-card .break-item{background:rgba(15,23,42,0.02);padding:10px;border-radius:8px}
.tool-card .fuel-result-card .break-item.wide{grid-column:span 2}
.tool-card .fuel-result-card .break-title{font-size:12px;color:#6b7280}
.tool-card .fuel-result-card .break-value{font-size:16px;font-weight:600;margin-top:6px;color:#0b1620}
.tool-card .fuel-result-card .break-notes{margin-top:12px;font-size:13px;color:#475569}

/* animations */
@keyframes pulseTotal{0%{transform:scale(1)}50%{transform:scale(1.03)}100%{transform:scale(1)}}
.tool-card .big-number.pulse{animation:pulseTotal 420ms ease-in-out}
@keyframes highlight{0%{box-shadow:0 0 0 rgba(15,98,254,0);transform:translateY(0)}40%{box-shadow:0 12px 24px rgba(15,98,254,0.06);transform:translateY(-2px)}100%{box-shadow:0 2px 8px rgba(15,23,42,0.03);transform:translateY(0)}}
.tool-card .result-updated{animation:highlight 700ms ease forwards}

/* small responsive tweaks */
@media (max-width:720px){.tool-card{margin:18px auto;padding:16px;width:calc(100% - 24px)}.tool-card .dropdown-list{top:48px;max-height:220px}}
@media (max-width:520px){.tool-card .actions{flex-direction:column;align-items:stretch}.tool-card .actions button{width:100%}}

/* final niceties */
.tool-card input,.tool-card select,.tool-card .selected-option{min-height:42px}
@media (min-width:1100px){.tool-card .form-grid>label:nth-last-child(1){min-width:180px}}
.tool-card:hover,.tool-card:focus{transform:translateY(0) !important}

/* -------------------------
   SEO section / article
   placed immediately after tool-card in markup
   ------------------------- */

/* Container for SEO content (keeps width consistent with tool) */
.seo-section,
#seo-content {
  --maxw:1020px;
  max-width:var(--maxw);
  margin:18px auto 40px;
  padding:18px 20px;
  box-sizing:border-box;
  background:transparent;
  color:#0b1620;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
}



/* Headings inside article */
.seo-section h2{font-size:20px;margin:0 0 10px;color:#0b1620;font-weight:700}
.seo-section h3{font-size:16px;margin:16px 0 8px;color:#0b1620;font-weight:600}
.seo-section p{margin:0 0 12px;color:#334155;font-size:15px}
.seo-section ul, .seo-section ol{margin:0 0 12px 20px;color:#334155}
.seo-section li{margin:6px 0}
.seo-section em{font-style:italic;color:#475569}

/* FAQ / definitions */
.seo-section dl{margin:12px 0 0}
.seo-section dt{font-weight:700;margin-top:12px;color:#0b1620}
.seo-section dd{margin:6px 0 12px;color:#475569}

/* Example inline code / strong */
.seo-section code{background:#f3f6ff;padding:2px 6px;border-radius:6px;font-size:13px;color:#0b1620}
.seo-section .example{display:block;background:#fbfcff;border:1px solid rgba(11,99,255,0.04);padding:10px;border-radius:8px;margin:8px 0;color:#0b1620;font-weight:600}

/* Two-column layout for larger viewports (helps readability) */
@media (min-width:960px) {
  .seo-section article{
    display:grid;
    grid-template-columns: 1fr;
    gap:18px;
  }
  .seo-section .two-col{
    display:grid;
    grid-template-columns: 1fr 300px;
    gap:18px;
    align-items:start;
  }
}

/* Make long paragraphs easier to read */
.seo-section article p{max-width:75ch}

/* Small print / disclaimer */
.seo-section .disclaimer{font-size:13px;color:#6b7280;margin-top:8px}

/* Accessibility: ensure focus styles for links in the article */
.seo-section a{color:var(--accent);text-decoration:underline}
.seo-section a:focus{outline:3px solid rgba(15,98,254,0.12);outline-offset:3px}

/* Schema / FAQ styling small tweaks */
.seo-section .faq-item{border-top:1px dashed rgba(15,23,42,0.04);padding-top:12px;margin-top:12px}
.seo-section .faq-item:first-child{border-top:0;padding-top:0;margin-top:0}

/* Add spacing so footer isn't cramped after long content */
@media (min-width:900px){
  .seo-section{margin-bottom:60px}
}
@media (max-width:899px){
  .seo-section{margin-bottom:36px;padding-left:12px;padding-right:12px}
}

/* -------------------------
   Minor utilities (scoped)
   ------------------------- */
.tool-card .muted-text{color:var(--muted);font-size:13px}
.tool-card .center{text-align:center}

/* small print for inputs */
.tool-card .field-note{font-size:12px;color:#6b7280;margin-top:8px}

/* Ensure print-friendly result (hide controls) */
@media print {
  .tool-card .actions,
  .tool-card label,
  .currency-dropdown,
  .dropdown-list,
  .slot,
  header, footer, #header, #footer { display: none !important; }
  .tool-card, .seo-section article { box-shadow:none !important; border:none !important; background:#fff !important; }
  .tool-card .fuel-result-card, .tool-card .result { page-break-inside:avoid; }
}

/* -------------------------
   Small bugfixes & overrides
   ------------------------- */
/* Restore original full width on dropdown */
.tool-card .dropdown-list {
  width: 100%;
  max-width: 100% !important;
  min-width: 240px;
}


/* ensure dropdown appears over seo-section on small viewports */
.tool-card .dropdown-list{z-index:9999}

/* minor reset for repeated class usage */
.seo-section img{max-width:100%;height:auto;border-radius:6px}

/* ======================
   Fix: align currency field with other inputs
   Paste at end of style.css
   ====================== */

/* Ensure all label controls inside the grid behave consistently */
.tool-card .form-grid label {
  display: flex;
  flex-direction: column;
  justify-content: flex-start; /* top-align label text + control */
  gap: 6px; /* consistent spacing between label text and control */
  box-sizing: border-box;
}

/* Make any direct child control stretch to full column width */
.tool-card .form-grid label > input,
.tool-card .form-grid label > select,
.tool-card .form-grid label > .currency-dropdown,
.tool-card .form-grid label > .selected-option {
  width: 100%;
  align-self: stretch;
  box-sizing: border-box;
  margin-top: 0; /* gap handles spacing now */
}

/* Ensure the currency-dropdown fills the label area and doesn't introduce extra offsets */
.tool-card .currency-dropdown {
  display: block;
  width: 100%;
}

/* Make the visible selected option match other input heights and paddings */
.tool-card .currency-dropdown .selected-option {
  min-height: 42px;
  padding: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
  box-sizing: border-box;
}

/* Make the list align to the width of the trigger (selected-option) */
.tool-card .currency-dropdown .dropdown-list {
  width: 100% !important;
  min-width: 240px; /* fallback on small screens */
  left: 0;
  right: auto;
}

/* Small screens: keep the same stacking but ensure no horizontal overflow */
@media (max-width:720px) {
  .tool-card .form-grid { grid-template-columns: 1fr; }
  .tool-card .currency-dropdown .dropdown-list { max-width: 100%; }
}

/* tiny visual tweak: ensure input-like controls all share same vertical rhythm */
.tool-card input[type="number"],
.tool-card select,
.tool-card .selected-option,
.tool-card .currency-dropdown .selected-option {
  padding-top: 10px;
  padding-bottom: 10px;
  min-height: 42px;
}

/* If any element previously had an extra top margin, reset it */
.tool-card .form-grid label > * { margin-top: 0 !important; }

/* ================================
   FORCE consistent vertical alignment
   Paste at the very end of style.css
   ================================ */

/* Make every label cell a strict column with a fixed gap */
.tool-card .form-grid > label {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  box-sizing: border-box !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Reset any stray margins from inner controls */
.tool-card .form-grid > label > * {
  margin: 0 !important;
  box-sizing: border-box !important;
}

/* Force all controls to the same height and vertical centering */
.tool-card .form-grid input[type="number"],
.tool-card .form-grid input[type="text"],
.tool-card .form-grid select,
.tool-card .form-grid .selected-option,
.tool-card .form-grid .currency-dropdown {
  min-height: 42px !important;
  height: 42px !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
  display: block !important;
  align-items: center !important;
  vertical-align: middle !important;
}

/* Make selected-option behave exactly like other inputs */
.tool-card .form-grid .selected-option {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}

/* Ensure the currency-dropdown uses full column width and list aligns to it */
.tool-card .form-grid .currency-dropdown {
  width: 100% !important;
  min-width: 0 !important;
  padding: 0 !important;
}
.tool-card .form-grid .currency-dropdown .dropdown-list {
  width: 100% !important;
  left: 0 !important;
  right: auto !important;
  min-width: 240px !important;
}

/* If any control is vertically offset by transforms, neutralize them */
.tool-card .form-grid select,
.tool-card .form-grid input,
.tool-card .form-grid .selected-option {
  transform: none !important;
  margin-top: 6px !important; /* keep same gap under label text */
}

/* Mobile fallback: single column layout keeps same rhythm */
@media (max-width:720px) {
  .tool-card .form-grid { grid-template-columns: 1fr !important; }
  .tool-card .form-grid > label { width: 100% !important; }
  .tool-card .form-grid .dropdown-list { max-width: 100% !important; }
}

.seo-section {
  margin: 22px auto 36px;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(246,250,252,0.6), rgba(255,255,255,0.6)) !important;
  border: 1px solid rgba(14,30,60,0.03);
  padding: 18px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.6;
  max-width: var(--maxw);
  width: calc(100% - 40px);
  box-sizing: border-box;
}