/* ============================================================
   ServiceSoftwareGuides — design system
   Work-order navy + dispatch blue + hi-vis amber.
   Display: Archivo · Body: Public Sans · Data: JetBrains Mono
   ============================================================ */
:root{
  --ink:#14253b; --ink-soft:#5a6b80; --paper:#ffffff; --slate:#f3f5f8;
  --blue:#1f5fcf; --blue-dark:#1647a0; --amber:#f59e0b; --amber-dark:#cf820a;
  --line:#e1e6ec; --good:#1f9d57; --bad:#d23f3f; --star:#f59e0b;
  --maxw:1120px; --content:760px;
  --f-display:"Archivo",-apple-system,sans-serif;
  --f-body:"Public Sans",-apple-system,sans-serif;
  --f-mono:"JetBrains Mono",monospace;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}*{transition:none!important;}}
body{font-family:var(--f-body);font-size:1.0625rem;line-height:1.65;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;}
a{color:var(--blue);text-underline-offset:2px;}
a:hover{color:var(--blue-dark);}
a:focus-visible,button:focus-visible{outline:3px solid var(--amber);outline-offset:2px;}
img{max-width:100%;height:auto;display:block;}
h1,h2,h3,h4{font-family:var(--f-display);line-height:1.12;letter-spacing:-.01em;}

/* header */
.hdr{background:var(--ink);position:sticky;top:0;z-index:50;}
.hdr-in{max-width:var(--maxw);margin:0 auto;padding:0 20px;height:62px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.brand{font-family:var(--f-display);font-weight:800;font-size:1.2rem;color:#fff;text-decoration:none;letter-spacing:-.02em;white-space:nowrap;}
.brand b{color:var(--amber);}
.nav{display:flex;gap:20px;align-items:center;}
.nav a{font-family:var(--f-body);font-weight:600;font-size:.88rem;color:#c7d2e0;text-decoration:none;}
.nav a:hover,.nav a[aria-current=page]{color:#fff;}
.nav-cta{background:var(--amber);color:var(--ink)!important;padding:7px 14px;border-radius:6px;font-weight:700!important;}
.nav-cta:hover{background:#fff;}

/* layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px;}
.section{max-width:var(--maxw);margin:0 auto;padding:52px 20px;}
.section-slate{background:var(--slate);}
.eyebrow{font-family:var(--f-mono);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--blue);margin-bottom:10px;}
.sec-head{font-family:var(--f-display);font-weight:800;font-size:1.7rem;letter-spacing:-.02em;margin-bottom:8px;}
.sec-sub{color:var(--ink-soft);margin-bottom:28px;max-width:60ch;}

/* hero */
.hero{background:linear-gradient(180deg,var(--ink) 0%,#1b3252 100%);color:#fff;}
.hero-in{max-width:var(--maxw);margin:0 auto;padding:64px 20px 56px;}
.hero h1{font-size:clamp(2.1rem,5vw,3.3rem);font-weight:800;max-width:16ch;color:#fff;}
.hero h1 b{color:var(--amber);font-weight:800;}
.hero p{margin-top:18px;font-size:1.18rem;color:#c7d2e0;max-width:52ch;}
.trust-line{margin-top:18px;font-family:var(--f-mono);font-size:.8rem;color:#9fb0c4;display:flex;align-items:center;gap:8px;}
.trust-line::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--good);box-shadow:0 0 0 3px rgba(31,157,87,.25);}

/* trade picker tiles */
.picker{margin-top:34px;}
.picker-label{font-family:var(--f-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:#9fb0c4;margin-bottom:12px;}
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.tile{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:10px;padding:16px 18px;text-decoration:none;color:#fff;display:flex;align-items:center;gap:12px;transition:.15s;}
.tile:hover{background:var(--amber);border-color:var(--amber);color:var(--ink);}
.tile .ic{width:28px;height:28px;flex:0 0 28px;}
.tile .t{font-family:var(--f-display);font-weight:700;font-size:1.02rem;}
.tile .a{margin-left:auto;font-family:var(--f-mono);font-size:1rem;opacity:.6;}

/* value props */
.props{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.prop{padding:22px;border:1px solid var(--line);border-radius:12px;background:var(--paper);}
.prop .ic{width:34px;height:34px;margin-bottom:12px;}
.prop h3{font-size:1.12rem;font-weight:700;margin-bottom:6px;}
.prop p{color:var(--ink-soft);font-size:.95rem;}

/* verdict card (signature element) */
.verdict{border:2px solid var(--ink);border-radius:12px;overflow:hidden;background:var(--paper);box-shadow:0 6px 0 rgba(20,37,59,.08);}
.verdict-top{background:var(--ink);color:#fff;padding:12px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.verdict-top .lbl{font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:#9fb0c4;}
.verdict-top .stamp{font-family:var(--f-display);font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);background:var(--amber);padding:4px 12px;border-radius:4px;transform:rotate(-2deg);}
.verdict-body{padding:20px 18px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;}
.verdict-body .pick{font-family:var(--f-display);font-weight:800;font-size:1.5rem;}
.verdict-body .why{color:var(--ink-soft);font-size:.95rem;flex:1;min-width:200px;}
.stars{color:var(--star);font-size:1.05rem;letter-spacing:1px;}
.stars small{color:var(--ink-soft);font-family:var(--f-mono);font-size:.78rem;margin-left:6px;}

/* CTA button (amber = action) */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--amber);color:var(--ink);font-family:var(--f-body);font-weight:700;font-size:.95rem;padding:11px 20px;border-radius:8px;text-decoration:none;border:none;cursor:pointer;white-space:nowrap;}
.btn:hover{background:var(--amber-dark);color:var(--ink);}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink);}
.btn-ghost:hover{border-color:var(--ink);background:var(--slate);}
.btn-blue{background:var(--blue);color:#fff;}
.btn-blue:hover{background:var(--blue-dark);color:#fff;}

/* cards / grids */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;}
.card{border:1px solid var(--line);border-radius:12px;background:var(--paper);padding:20px;display:flex;flex-direction:column;gap:10px;transition:.15s;text-decoration:none;color:inherit;}
.card:hover{border-color:var(--ink);box-shadow:0 4px 14px rgba(20,37,59,.07);}
.card .tag{font-family:var(--f-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);font-weight:600;}
.card h3{font-size:1.14rem;font-weight:700;line-height:1.25;}
.card p{color:var(--ink-soft);font-size:.92rem;}
.card .more{margin-top:auto;font-weight:700;font-size:.9rem;color:var(--blue);}

/* category chips */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.cat{border:1px solid var(--line);border-radius:10px;padding:18px;text-decoration:none;background:var(--paper);transition:.15s;}
.cat:hover{border-color:var(--blue);box-shadow:0 4px 14px rgba(31,95,207,.1);}
.cat .t{font-family:var(--f-display);font-weight:700;font-size:1.06rem;color:var(--ink);}
.cat .d{color:var(--ink-soft);font-size:.88rem;margin-top:4px;}

/* comparison + spec tables */
.cmp{width:100%;border-collapse:collapse;font-size:.95rem;margin:0 0 24px;border:1px solid var(--line);border-radius:10px;overflow:hidden;}
.cmp th{background:var(--ink);color:#fff;font-family:var(--f-display);font-weight:700;text-align:left;padding:12px 14px;font-size:.9rem;}
.cmp td{border-top:1px solid var(--line);padding:11px 14px;vertical-align:top;}
.cmp tr:nth-child(even) td{background:var(--slate);}
.cmp .feat{font-weight:600;}
.tick{color:var(--good);font-weight:700;}
.cross{color:var(--bad);font-weight:700;}

/* pros/cons */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:0 0 24px;}
.pc .box{border:1px solid var(--line);border-radius:10px;padding:16px 18px;}
.pc .box.pros{border-top:3px solid var(--good);}
.pc .box.cons{border-top:3px solid var(--bad);}
.pc h4{font-size:1rem;margin-bottom:10px;}
.pc ul{list-style:none;}
.pc li{padding-left:24px;position:relative;margin-bottom:7px;font-size:.93rem;}
.pc .pros li::before{content:"✓";position:absolute;left:0;color:var(--good);font-weight:700;}
.pc .cons li::before{content:"✕";position:absolute;left:0;color:var(--bad);font-weight:700;}

/* disclosure + notes */
.disclosure{background:var(--slate);border-left:3px solid var(--amber);padding:11px 16px;font-size:.85rem;font-family:var(--f-mono);color:var(--ink-soft);border-radius:0 8px 8px 0;}
.disclosure b{color:var(--amber-dark);}
.note{background:#fff8ec;border:1px solid #f3dcae;border-radius:10px;padding:16px 18px;margin:0 0 22px;}
.note .l{font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--amber-dark);font-weight:600;display:block;margin-bottom:6px;}

/* article/page bodies */
.breadcrumb{max-width:var(--content);margin:0 auto;padding:18px 20px 0;font-family:var(--f-mono);font-size:.74rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;}
.breadcrumb a{color:var(--ink-soft);text-decoration:none;}
.breadcrumb a:hover{color:var(--blue);}
.arthead{max-width:var(--content);margin:0 auto;padding:14px 20px 6px;}
.arthead .tag{font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);font-weight:600;}
.arthead h1{font-size:clamp(1.8rem,4.4vw,2.6rem);font-weight:800;margin:8px 0;}
.arthead .meta{font-family:var(--f-mono);font-size:.76rem;color:var(--ink-soft);}
.body{max-width:var(--content);margin:0 auto;padding:14px 20px 30px;}
.body>p:first-of-type{font-size:1.14rem;}
.body h2{font-size:1.5rem;font-weight:800;margin:38px 0 12px;}
.body h3{font-size:1.18rem;font-weight:700;margin:26px 0 8px;}
.body p{margin:0 0 16px;}
.body ul,.body ol{margin:0 0 16px 22px;}
.body li{margin-bottom:7px;}
.body .verdict,.body .cmp,.body .pc{margin-top:8px;}

/* page (static) */
.page{max-width:var(--content);margin:0 auto;padding:46px 20px 60px;}
.page h1{font-size:clamp(1.8rem,4vw,2.4rem);font-weight:800;margin-bottom:20px;}
.page h2{font-size:1.35rem;font-weight:800;margin:34px 0 12px;}
.page h3{font-size:1.08rem;font-weight:700;margin:22px 0 8px;}
.page p,.page ul,.page ol{margin-bottom:14px;}
.page ul,.page ol{margin-left:22px;}
.page li{margin-bottom:7px;}

/* author + img */
.author{max-width:var(--content);margin:40px auto 0;padding:20px;border:1px solid var(--line);border-radius:12px;display:flex;gap:16px;align-items:center;}
.author .av{width:60px;height:60px;border-radius:50%;flex:0 0 60px;background:var(--ink);}
.author .who{font-family:var(--f-display);font-weight:700;}
.author .bio{color:var(--ink-soft);font-size:.9rem;margin-top:3px;}
.art-hero{width:100%;border-radius:12px;border:1px solid var(--line);margin:0 0 22px;}

/* newsletter */
.nl{background:var(--ink);border-radius:14px;padding:32px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;}
.nl h3{color:#fff;font-size:1.4rem;font-weight:800;}
.nl p{color:#9fb0c4;font-size:.95rem;margin-top:6px;max-width:46ch;}
.nl form{display:flex;gap:8px;min-width:320px;}
.nl input{flex:1;border:none;border-radius:8px;padding:12px 14px;font-family:var(--f-body);font-size:1rem;}
.nl .ok{color:var(--good);font-family:var(--f-mono);font-size:.85rem;margin-top:10px;}

/* contact form */
.form{display:grid;gap:14px;max-width:460px;margin-top:24px;}
.form label{font-family:var(--f-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;display:block;}
.form input,.form textarea{width:100%;border:1px solid var(--ink);border-radius:8px;padding:10px 12px;font-family:var(--f-body);font-size:1rem;}

/* footer */
.ft{background:var(--ink);color:#c7d2e0;margin-top:50px;}
.ft-top{max-width:var(--maxw);margin:0 auto;padding:42px 20px 28px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:28px;}
.ft .brand{font-size:1.25rem;}
.ft-col h4{font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:#9fb0c4;margin-bottom:12px;}
.ft-col a{display:block;color:#c7d2e0;text-decoration:none;font-size:.9rem;margin-bottom:8px;}
.ft-col a:hover{color:#fff;}
.ft-tag{font-size:.88rem;color:#9fb0c4;margin-top:10px;max-width:32ch;}
.ft-bot{border-top:1px solid rgba(255,255,255,.12);}
.ft-bot-in{max-width:var(--maxw);margin:0 auto;padding:16px 20px;display:flex;flex-wrap:wrap;gap:10px 24px;justify-content:space-between;font-family:var(--f-mono);font-size:.74rem;color:#9fb0c4;}
.ft-bot-in a{color:#9fb0c4;text-decoration:none;}

/* responsive */
@media(max-width:820px){
  .tiles{grid-template-columns:repeat(2,1fr);}
  .props,.cats{grid-template-columns:1fr;}
  .nl{grid-template-columns:1fr;}
  .nl form{min-width:0;}
  .ft-top{grid-template-columns:1fr 1fr;}
  .ft .brand{grid-column:1/-1;}
  .pc{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .hdr-in{height:auto;flex-direction:column;gap:8px;padding:12px 20px;}
  .nav{flex-wrap:wrap;justify-content:center;gap:14px;}
  .tiles{grid-template-columns:1fr;}
  .verdict-body .pick{font-size:1.3rem;}
}

/* affiliate cta marker */
.cta-aff{}

/* hero illustration + article banners */
.hero-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:34px;align-items:center;}
.hero-art img{width:100%;border-radius:14px;}
.art-hero{width:100%;border:1px solid var(--line);border-radius:12px;margin:0 0 22px;display:block;}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;}.hero-art{display:none;}}

/* screenshot slot */
.shot-slot{border:2px dashed var(--blue);border-radius:12px;background:#eef3fc;padding:26px;text-align:center;color:var(--ink-soft);margin:0 0 22px;display:flex;flex-direction:column;align-items:center;gap:8px;}
.shot-ic{font-size:1.8rem;}
.shot-slot strong{color:var(--ink);}
.shot-slot small{font-size:.8rem;line-height:1.5;}
