/* ToolPortal Utility Page v3
   Fixed inner-page UI for real tools: tool first, direct answer, decision support, examples, FAQ. */
@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@500;600&display=swap");

    :root{
      --bg:#f7f4ec;
      --paper:#fffdfa;
      --ink:#102236;
      --text:#31465b;
      --muted:#526679;
      --line:#ded3c2;
      --line2:#cdbfae;
      --blue:#1f5eff;
      --blue2:#0a3fb4;
      --green:#0d8b6f;
      --cream:#fff6e8;
      --amber:#d9861f;
      --red:#c84444;
      --shadow:0 18px 52px rgba(39,49,62,.10);
      --radius:14px;
      --mono:"IBM Plex Mono", ui-monospace, monospace;
      --sans:"DM Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    }

    *{box-sizing:border-box}
    html{background:var(--bg);scroll-behavior:smooth;overflow-x:hidden}
    body{
      margin:0;
      min-height:100vh;
      color:var(--text);
      background:
        linear-gradient(90deg, rgba(16,34,54,.045) 1px, transparent 1px) 0 0/48px 48px,
        linear-gradient(180deg,#fbf7ef 0%,#f7f4ec 48%,#f8fafc 100%);
      font-family:var(--sans);
      line-height:1.62;
      letter-spacing:0;
      overflow-x:hidden;
    }
    a{color:var(--blue2);text-underline-offset:3px}
    button,input,select,textarea{font:inherit;letter-spacing:0}
    code,pre,textarea{font-family:var(--mono)}
    .shell{width:min(1180px,calc(100% - 32px));margin:0 auto}
    .top{
      position:sticky;top:0;z-index:20;
      min-height:68px;
      display:flex;align-items:center;justify-content:space-between;gap:16px;
      border-bottom:1px solid rgba(222,211,194,.88);
      background:rgba(255,253,250,.9);
      backdrop-filter:blur(18px);
    }
    .brand{display:inline-flex;align-items:center;gap:10px;color:var(--ink);font-weight:800;text-decoration:none}
    .brand-mark{width:28px;height:28px;border-radius:9px;background:linear-gradient(135deg,var(--blue),var(--green));box-shadow:0 14px 28px rgba(31,94,255,.22)}
    .nav{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
    .nav a{display:inline-flex;align-items:center;min-height:38px;padding:0 12px;border-radius:10px;color:#41566b;text-decoration:none;font-size:14px;font-weight:700}
    .nav a:hover{background:#eef3ff;color:var(--blue2)}
    .nav a[href="/contact/"]{background:var(--ink);color:#fff}
    main{padding:34px 0 56px}
    .crumb{display:flex;gap:8px;align-items:center;margin-bottom:18px;color:#526273;font-size:14px}
    .crumb a{color:#30465a;text-decoration:none}
    .hero{
      display:grid;
      grid-template-columns:minmax(0,1fr) minmax(380px,470px);
      gap:24px;
      align-items:start;
      min-width:0;
    }
    .card,.panel,.section,.tool-card{
      border:1px solid var(--line);
      border-radius:var(--radius);
      background:rgba(255,253,250,.96);
      box-shadow:0 1px 2px rgba(16,34,54,.04);
      min-width:0;
    }
    .hero-copy{padding:34px}
    .eyebrow{
      display:inline-flex;align-items:center;gap:8px;
      min-height:30px;padding:5px 10px;border-radius:999px;
      border:1px solid #c8d8ff;background:#eef4ff;color:#164fc7;
      font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
    }
    h1,h2,h3{margin:0;color:var(--ink);letter-spacing:0}
    h1{margin-top:16px;max-width:760px;font-size:clamp(2.45rem,5.2vw,4.65rem);line-height:.94;font-weight:800}
    h2{font-size:clamp(1.55rem,2.8vw,2.45rem);line-height:1.04;font-weight:750}
    h3{font-size:1.12rem;line-height:1.22;font-weight:760}
    p{margin:0;color:var(--text)}
    p+p{margin-top:10px}
    .lead{margin-top:18px;max-width:66ch;font-size:1.08rem;color:#40576c}
    .hero-list{margin:22px 0 0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;list-style:none}
    .hero-list li{padding:12px;border:1px solid var(--line);border-radius:12px;background:#fff8ee}
    .hero-list b{display:block;color:var(--ink);font-size:13px;text-transform:uppercase;letter-spacing:.06em}
    .hero-list span{display:block;margin-top:4px;color:var(--muted);font-size:14px}
    .tool-card{padding:22px;box-shadow:var(--shadow)}
    .tool-card header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
    .tool-card header p{font-size:14px;color:var(--muted)}
    .status-pill{display:inline-flex;align-items:center;min-height:30px;padding:5px 9px;border-radius:999px;background:#eaf9f4;color:#087057;border:1px solid #bee7d9;font-size:12px;font-weight:800;white-space:nowrap}
    .field{display:grid;gap:6px;margin-top:12px}
    .field label,.input-label{font-size:13px;font-weight:800;color:#243c55}
    textarea,input,select{
      width:100%;
      border:1px solid #cfd8e2;
      border-radius:12px;
      background:#fff;
      color:#102236;
      padding:11px 12px;
      min-width:0;
    }
    textarea{min-height:170px;resize:vertical;font-size:13px;line-height:1.55}
    textarea.short{min-height:112px}
    .control-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
    .upload-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px}
    .upload-row label{
      display:inline-flex;align-items:center;justify-content:center;
      min-height:42px;padding:10px 13px;border-radius:12px;
      background:#ecf2ff;color:#174fc4;border:1px solid #cddcff;font-weight:800;cursor:pointer;
    }
    .upload-row span{font-size:13px;color:var(--muted)}
    input[type=file]{display:none}
    .btns{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
    button{
      min-height:42px;border:0;border-radius:12px;padding:10px 14px;
      font-weight:800;cursor:pointer;
    }
    .primary{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff}
    .secondary{background:#eef4ff;color:#164fc7;border:1px solid #cddcff}
    .danger{background:#fff2f2;color:#b33939;border:1px solid #efcaca}
    .ghost{background:#fff;border:1px solid var(--line2);color:#2d455b}
    .result-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(330px,.82fr);gap:18px;margin-top:18px;min-width:0}
    .result-grid>*{min-width:0}
    .panel{padding:22px}
    .kicker{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#174fc4}
    .chips,.stats,.issues,.examples,.faq,.related-grid{display:grid;gap:10px}
    .chips{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:14px}
    .chip{display:inline-flex;align-items:center;min-height:34px;padding:7px 10px;border-radius:999px;border:1px solid #cfd8e2;background:#fff;color:#344c62;font-size:12px;font-weight:800;overflow-wrap:anywhere}
    .stats{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:14px}
    .stat,.issue,.example,.faq-card,.related-card,.answer-card{
      border:1px solid var(--line);
      border-radius:12px;
      background:#fffdfa;
      padding:14px;
      min-width:0;
    }
    .stat span{display:block;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#526679}
    .stat strong{display:block;margin-top:4px;color:var(--ink);font-size:24px}
    .status{margin-top:14px;border-radius:12px;border:1px solid var(--line);padding:14px;background:#fff8ee}
    .status small{display:block;font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:#6c7c8b}
    .status strong{display:block;margin-top:5px;color:var(--ink);font-size:18px}
    .status.good{background:#edf9f5;border-color:#bee7d9}
    .status.warn{background:#fff8e8;border-color:#ead3a9}
    .status.bad{background:#fff2f2;border-color:#efcaca}
    .issue em{font-style:normal;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#526679}
    .issue.good{background:#edf9f5;border-color:#bee7d9}
    .issue.warn{background:#fff8e8;border-color:#ead3a9}
    .issue.error{background:#fff2f2;border-color:#efcaca}
    .table,.report{margin-top:12px;border:1px solid var(--line);border-radius:12px;background:#fff;overflow:auto;max-width:100%;min-width:0}
    .table.empty,.report.empty{display:grid;place-items:center;min-height:86px;padding:16px;color:var(--muted);border-style:dashed}
    table{width:100%;border-collapse:collapse;font-size:13px;min-width:620px}
    th,td{padding:10px 11px;border-bottom:1px solid #e8ded1;text-align:left;vertical-align:top}
    th{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#53687a;background:#fff6e8}
    td code{font-size:12px;background:#f2f5f8;border-radius:7px;padding:2px 5px}
    .pill{display:inline-flex;align-items:center;justify-content:center;min-width:64px;min-height:26px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase}
    .pill.allow{background:#eaf9f4;color:#087057}
    .pill.block{background:#fff0f0;color:#b33939}
    .support-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(310px,.82fr);gap:16px;min-width:0}
    .support-grid>*{min-width:0}
    .box{border:1px solid var(--line);border-radius:12px;background:#fffdfa;padding:14px;min-width:0}
    .box+.box{margin-top:12px}
    .box ul{margin:0;padding-left:18px;color:var(--text)}
    .headers{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
    .headers span{padding:7px 9px;border-radius:999px;border:1px solid #cfd8e2;background:#fff;font-size:12px;font-weight:700;overflow-wrap:anywhere}
    .headers .warn{background:#fff8e8;border-color:#ead3a9;color:#986314}
    .headers .bad{background:#fff0f0;border-color:#efcaca;color:#b33939}
    .report pre{margin:0;padding:14px;white-space:pre-wrap;word-break:break-word;font-size:12px;line-height:1.65;color:#20394f;background:#fffdfa}
    .section{margin-top:18px;padding:26px}
    .answer-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
    .examples,.faq,.related-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:14px}
    .faq{grid-template-columns:repeat(2,minmax(0,1fr))}
    .example b,.answer-card b{display:block;margin-bottom:6px;color:#164fc7;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
    .decision-table{overflow:auto;margin-top:14px}
    .decision-table table{min-width:760px}
    .footer{padding:24px 0 38px;color:var(--muted);font-size:13px}
    @media (max-width:980px){
      .hero,.result-grid,.support-grid,.answer-grid,.examples,.faq,.related-grid,.hero-list{display:grid;grid-template-columns:minmax(0,1fr) !important;max-width:100%;min-width:0}
      .hero>*,.result-grid>*,.support-grid>*,.answer-grid>*,.examples>*,.faq>*,.related-grid>*,.hero-list>*{width:100%;max-width:100%;min-width:0}
      h1{font-size:clamp(2.2rem,11vw,3.6rem)}
      .hero-copy,.tool-card,.panel,.section{padding:20px}
      .chips,.stats,.control-grid{grid-template-columns:1fr}
      .table,.report,.decision-table{width:100%;max-width:100%;min-width:0;overflow-x:auto}
      table,.decision-table table{width:max-content;min-width:620px}
      .top{align-items:flex-start;padding:12px 0}
      .nav{justify-content:flex-start}
      .btns button{white-space:normal;overflow-wrap:anywhere}
    }
