/* ============================================================
   filelocator.net — sitewide stylesheet
   Design language: "search-hit" — deep ink, paper white,
   match-highlight yellow, mono file paths.
   Used by every page on the site (load from /css/style.css).
   ============================================================ */

:root{
  --ink:#1B2733;          /* primary text / dark surfaces */
  --ink-soft:#33455A;
  --slate:#54657A;        /* secondary text */
  --line:#E3E9F0;         /* hairlines & borders */
  --paper:#FFFFFF;        /* page background */
  --mist:#F4F7FA;         /* tinted panels */
  --hit:#FFE56B;          /* search-match highlight (signature) */
  --hit-deep:#F5C211;
  --link:#0F62D7;         /* hyperlink blue */
  --ok:#0E8A5F;           /* "found" green for positives */
  --warn:#C2410C;         /* cons / cautions */

  --font-display:"Bricolage Grotesque","Inter",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-mono:"IBM Plex Mono",ui-monospace,"SF Mono",Consolas,monospace;

  --radius:10px;
  --maxw:1120px;
  --shadow:0 10px 30px rgba(27,39,51,.10);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}

body{
  margin:0;
  font-family:var(--font-body);
  font-size:1.0625rem;
  line-height:1.65;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--link);text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{text-decoration-thickness:2px}
:focus-visible{outline:3px solid var(--hit-deep);outline-offset:2px;border-radius:4px}

h1,h2,h3{font-family:var(--font-display);line-height:1.12;letter-spacing:-.015em;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:800}
h2{font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:700}
h3{font-size:1.17rem;font-weight:700}
p{margin:.4em 0 1em}

mark,.hl{
  background:linear-gradient(180deg,transparent 8%,var(--hit) 8%,var(--hit) 88%,transparent 88%);
  color:inherit;padding:0 .12em;border-radius:2px;
}

.mono{font-family:var(--font-mono)}
.eyebrow{
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--slate);display:inline-flex;gap:.5em;align-items:center;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--hit-deep)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:62px 0}
.section--mist{background:var(--mist)}
.section-head{max-width:680px;margin-bottom:30px}
.section-head p{color:var(--slate)}

/* ---------- header ---------- */
.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.6em 1em;z-index:99}
.skip-link:focus{left:12px;top:12px}

.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex;align-items:center;gap:26px;min-height:64px}
.brand{display:flex;align-items:baseline;gap:2px;font-family:var(--font-display);
  font-weight:800;font-size:1.22rem;color:var(--ink);text-decoration:none}
.brand .tld{color:var(--slate);font-weight:600}
.brand .dot{color:var(--hit-deep)}

.site-nav{margin-left:auto}
.site-nav ul{display:flex;gap:4px;list-style:none;margin:0;padding:0}
.site-nav a{
  display:block;padding:.45em .8em;border-radius:8px;color:var(--ink-soft);
  text-decoration:none;font-weight:600;font-size:.95rem;
}
.site-nav a:hover,.site-nav a[aria-current="page"]{background:var(--mist);color:var(--ink)}
.nav-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--line);
  border-radius:8px;padding:.5em .7em;font:inherit;cursor:pointer}

@media (max-width:860px){
  .nav-toggle{display:block}
  .site-nav{position:absolute;left:0;right:0;top:100%;background:var(--paper);
    border-bottom:1px solid var(--line);display:none;margin:0}
  .site-nav.open{display:block}
  .site-nav ul{flex-direction:column;padding:10px 16px 16px}
}

/* ---------- breadcrumbs ---------- */
.breadcrumbs{font-family:var(--font-mono);font-size:.8rem;color:var(--slate);padding:18px 0 0}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.35em;margin:0;padding:0}
.breadcrumbs li+li::before{content:"/";margin-right:.35em;color:var(--line)}
.breadcrumbs a{color:var(--slate)}

/* ---------- hero ---------- */
.hero{padding:72px 0 56px;background:
  radial-gradient(1200px 420px at 85% -10%,#FFF6CF 0%,transparent 60%),var(--paper)}
.hero .wrap{max-width:880px}
.hero h1{margin-bottom:.35em}
.hero .lede{font-size:1.18rem;color:var(--slate);max-width:620px}

.finder{position:relative;margin:30px 0 14px}
.finder-box{
  display:flex;align-items:center;gap:12px;background:#fff;border:2px solid var(--ink);
  border-radius:14px;padding:14px 18px;box-shadow:var(--shadow);
}
.finder-box svg{flex:none}
.finder-box input{
  flex:1;border:0;font:500 1.05rem/1.3 var(--font-mono);color:var(--ink);
  background:transparent;min-width:0;
}
.finder-box input:focus{outline:none}
.finder-box kbd{
  font-family:var(--font-mono);font-size:.72rem;color:var(--slate);
  border:1px solid var(--line);border-bottom-width:2px;border-radius:6px;padding:.15em .5em;background:var(--mist);
}
.finder-results{
  position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:40;background:#fff;
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);
  max-height:380px;overflow:auto;display:none;
}
.finder-results.open{display:block}
.finder-results a{
  display:block;padding:12px 18px;text-decoration:none;color:var(--ink);
  border-bottom:1px solid var(--mist);
}
.finder-results a:hover,.finder-results a.active{background:var(--mist)}
.finder-results .r-title{font-weight:600}
.finder-results .r-path{font-family:var(--font-mono);font-size:.76rem;color:var(--slate)}
.finder-results .empty{padding:14px 18px;color:var(--slate);font-size:.95rem}

.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chips span{font-family:var(--font-mono);font-size:.78rem;color:var(--slate);padding:.3em 0}
.chips a{
  font-family:var(--font-mono);font-size:.8rem;color:var(--ink);text-decoration:none;
  border:1px solid var(--line);border-radius:999px;padding:.32em .85em;background:#fff;
}
.chips a:hover{border-color:var(--ink);background:var(--hit)}

.hero-stats{display:flex;gap:34px;flex-wrap:wrap;margin-top:34px;
  font-family:var(--font-mono);font-size:.82rem;color:var(--slate)}
.hero-stats b{display:block;font:800 1.5rem/1 var(--font-display);color:var(--ink);margin-bottom:4px}

/* ---------- cards & grids ---------- */
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:920px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-3,.grid-4{grid-template-columns:1fr}}

.card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#C9D4E0}
.card h3 a{color:var(--ink);text-decoration:none}
.card h3 a::after{content:"";position:absolute;inset:0}
.card p{color:var(--slate);font-size:.95rem;margin-bottom:0}
.card .path{font-family:var(--font-mono);font-size:.74rem;color:var(--slate);display:block;margin-bottom:10px}
.card .meta{font-family:var(--font-mono);font-size:.74rem;color:var(--ok);margin-top:12px;display:block}

.card--feature{border-top:4px solid var(--hit-deep)}
.badge{
  position:absolute;top:-12px;right:14px;background:var(--ink);color:var(--hit);
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;
  padding:.3em .7em;border-radius:6px;
}

/* ---------- list rows (file-row style) ---------- */
.rows{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.rows a{
  display:grid;grid-template-columns:1fr auto;gap:4px 18px;align-items:center;
  padding:15px 20px;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--mist);
}
.rows a:last-child{border-bottom:0}
.rows a:hover{background:var(--mist)}
.rows .r-title{font-weight:600}
.rows .r-path{font-family:var(--font-mono);font-size:.76rem;color:var(--slate);grid-column:1}
.rows .r-go{font-family:var(--font-mono);color:var(--slate);grid-row:span 2}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;font-weight:700;text-decoration:none;border-radius:10px;
  padding:.72em 1.35em;border:2px solid var(--ink);color:var(--ink);background:#fff;
  transition:background .15s,transform .15s;
}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--ink);color:#fff}
.btn--primary:hover{background:var(--ink-soft)}
.btn--buy{background:var(--hit);border-color:var(--hit-deep);color:var(--ink)}
.btn--buy:hover{background:var(--hit-deep)}
.btn--sm{padding:.5em 1em;font-size:.92rem}

/* ---------- affiliate / gear ---------- */
.gear-card{display:flex;flex-direction:column}
.gear-card .gear-img{
  background:var(--mist);border-radius:8px;height:150px;display:flex;
  align-items:center;justify-content:center;margin-bottom:16px;color:var(--slate);
  font-family:var(--font-mono);font-size:.78rem;
}
.gear-card .why{font-size:.92rem;color:var(--slate);flex:1}
.gear-card .btn{margin-top:14px;text-align:center}
.gear-card .spec{font-family:var(--font-mono);font-size:.74rem;color:var(--ok);margin:.4em 0 0}

.disclosure{
  font-size:.85rem;color:var(--slate);background:var(--mist);border-left:3px solid var(--hit-deep);
  padding:10px 16px;border-radius:0 8px 8px 0;margin:0 0 26px;
}

/* ---------- comparison tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius)}
table{border-collapse:collapse;width:100%;font-size:.95rem;background:#fff}
caption{caption-side:bottom;font-size:.8rem;color:var(--slate);padding:10px;text-align:left}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--mist)}
thead th{background:var(--ink);color:#fff;font-family:var(--font-mono);font-size:.78rem;
  letter-spacing:.04em;text-transform:uppercase;font-weight:600}
tbody tr:hover{background:var(--mist)}
td .yes{color:var(--ok);font-weight:700}
td .no{color:var(--warn);font-weight:700}

/* ---------- pros / cons ---------- */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0}
@media (max-width:640px){.proscons{grid-template-columns:1fr}}
.proscons div{border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;background:#fff}
.proscons h3{font-size:1rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}
.proscons .pros h3{color:var(--ok)}.proscons .cons h3{color:var(--warn)}
.proscons ul{margin:0;padding-left:1.2em}

/* ---------- FAQ ---------- */
.faq details{border:1px solid var(--line);border-radius:var(--radius);background:#fff;
  padding:0 22px;margin-bottom:12px}
.faq summary{cursor:pointer;font-weight:700;padding:16px 0;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:0;font-family:var(--font-mono);
  font-size:1.2rem;color:var(--slate)}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--ink-soft);padding-bottom:16px;margin:0}

/* ---------- article / prose pages ---------- */
.prose{max-width:760px}
.prose h2{margin-top:1.8em}
.prose h3{margin-top:1.4em}
.prose ul,.prose ol{padding-left:1.3em}
.prose li{margin:.35em 0}
.prose blockquote{border-left:3px solid var(--hit-deep);margin:1.2em 0;padding:.2em 1.1em;
  color:var(--ink-soft);background:var(--mist);border-radius:0 8px 8px 0}
.prose code{font-family:var(--font-mono);font-size:.88em;background:var(--mist);
  padding:.15em .4em;border-radius:5px;border:1px solid var(--line)}
.prose pre{background:var(--ink);color:#E8EEF5;padding:18px 22px;border-radius:var(--radius);
  overflow-x:auto;font-family:var(--font-mono);font-size:.88rem;line-height:1.6}
.prose pre code{background:none;border:0;padding:0;color:inherit}
.toc{border:1px solid var(--line);border-radius:var(--radius);background:var(--mist);
  padding:18px 24px;margin:24px 0;font-size:.95rem}
.toc strong{font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--slate)}
.toc ol{margin:.5em 0 0;padding-left:1.3em}
.updated{font-family:var(--font-mono);font-size:.78rem;color:var(--slate)}

/* ---------- verdict box (reviews) ---------- */
.verdict{background:var(--ink);color:#fff;border-radius:var(--radius);padding:26px 30px;margin:26px 0}
.verdict h3{color:var(--hit)}
.verdict .score{font:800 2.4rem/1 var(--font-display)}
.verdict p{color:#C8D3DF}

/* ---------- CTA band ---------- */
.cta-band{background:var(--ink);color:#fff;border-radius:16px;padding:40px;
  display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between}
.cta-band h2{margin:0;color:#fff}
.cta-band p{color:#C8D3DF;margin:.4em 0 0}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#B9C6D4;margin-top:70px;
  font-size:.92rem}
.site-footer a{color:#E4ECF4;text-decoration:none}
.site-footer a:hover{color:var(--hit)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:30px;padding:54px 0 30px}
@media (max-width:920px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h3{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.07em;
  text-transform:uppercase;color:#8FA1B3;font-weight:600}
.footer-grid ul{list-style:none;margin:0;padding:0}
.footer-grid li{margin:.45em 0}
.footer-brand p{max-width:280px;font-size:.88rem}
.footer-bottom{border-top:1px solid #2C3B4B;padding:20px 0;display:flex;flex-wrap:wrap;
  gap:14px;justify-content:space-between;font-family:var(--font-mono);font-size:.76rem;color:#8FA1B3}
.footer-bottom a{color:#B9C6D4}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ---------- print ---------- */
@media print{
  .site-header,.site-footer,.finder,.chips,.cta-band,.nav-toggle{display:none}
  body{font-size:11pt}
}
