/* ============================================================
   Sharaj Tools — styles.css
   Minimal, light, marketplace aesthetic
   ============================================================ */

:root{
  --bg:#faf8f5;
  --surface:#ffffff;
  --ink:#1a1714;
  --ink-soft:#6b645c;
  --line:#e9e3da;
  --line-strong:#d8d0c4;
  --accent:#e0532f;        /* warm marketplace coral */
  --accent-dark:#c3431f;
  --radius:16px;
  --shadow:0 1px 2px rgba(26,23,20,.04), 0 8px 24px rgba(26,23,20,.05);
  --shadow-hover:0 4px 8px rgba(26,23,20,.06), 0 18px 44px rgba(26,23,20,.10);
  --maxw:1140px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:"Hanken Grotesk",-apple-system,sans-serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.narrow{max-width:720px}
a{color:inherit}

/* ===== top bar ===== */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(250,248,245,.82);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{
  font-family:"Fraunces",serif;font-weight:600;font-size:1.35rem;
  text-decoration:none;letter-spacing:-.01em;display:flex;align-items:center;gap:8px;
}
.brand-mark{color:var(--accent);font-size:.9rem}
.brand-light{color:var(--ink-soft);font-weight:400}
.topnav{display:flex;gap:30px}
.topnav a{text-decoration:none;color:var(--ink-soft);font-weight:500;font-size:.95rem;transition:color .2s}
.topnav a:hover{color:var(--ink)}

/* ===== hero ===== */
.hero{padding:72px 0 52px;text-align:center}
.eyebrow{
  font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-dark);font-weight:600;margin-bottom:22px;
}
.hero h1{
  font-family:"Fraunces",serif;font-weight:600;
  font-size:clamp(2.4rem,6vw,4.2rem);line-height:1.04;letter-spacing:-.025em;
  margin-bottom:22px;
}
.hero h1 em{font-style:italic;color:var(--accent)}
.lede{
  font-size:clamp(1.05rem,2.2vw,1.22rem);color:var(--ink-soft);
  max-width:580px;margin:0 auto 38px;
}

/* search */
.search{
  display:flex;align-items:center;gap:12px;
  max-width:560px;margin:0 auto;
  background:var(--surface);border:1px solid var(--line-strong);
  border-radius:100px;padding:6px 6px 6px 22px;
  box-shadow:var(--shadow);transition:border-color .2s,box-shadow .2s;
}
.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px rgba(224,83,47,.12)}
.search-ic{width:20px;height:20px;color:var(--ink-soft);flex:none}
.search input{
  flex:1;border:0;outline:0;background:none;
  font-family:inherit;font-size:1.02rem;color:var(--ink);padding:12px 0;
}
.search input::placeholder{color:#aaa298}

/* ===== toolbar / filters ===== */
.toolbar{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:14px;margin:8px 0 26px;
}
.filters{display:flex;gap:10px;flex-wrap:wrap}
.chip{
  font-family:inherit;font-size:.92rem;font-weight:500;cursor:pointer;
  background:var(--surface);color:var(--ink-soft);
  border:1px solid var(--line-strong);border-radius:100px;padding:9px 18px;
  transition:all .18s;
}
.chip:hover{color:var(--ink);border-color:var(--ink-soft)}
.chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.count{font-size:.88rem;color:var(--ink-soft)}

/* ===== grid + cards ===== */
.grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:20px;padding-bottom:20px;
}
.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:24px;
  display:flex;flex-direction:column;gap:6px;
  box-shadow:var(--shadow);
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,border-color .25s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:var(--line-strong)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.logo{
  width:48px;height:48px;border-radius:13px;display:grid;place-items:center;
  overflow:hidden;background:var(--bg);border:1px solid var(--line);
}
.logo img{width:100%;height:100%;object-fit:contain;display:block}
.badge{
  font-size:.74rem;font-weight:600;color:var(--ink-soft);
  background:var(--bg);border:1px solid var(--line);border-radius:100px;padding:4px 11px;
}
.card h3{font-family:"Fraunces",serif;font-weight:600;font-size:1.3rem;letter-spacing:-.01em}
.card .role{font-size:.82rem;font-weight:600;color:var(--accent-dark);text-transform:uppercase;letter-spacing:.04em}
.card .desc{color:var(--ink-soft);font-size:.95rem;margin:8px 0 18px;flex:1}
.cta{
  align-self:flex-start;text-decoration:none;
  font-weight:600;font-size:.92rem;color:#fff;background:var(--ink);
  padding:11px 20px;border-radius:10px;transition:background .2s,transform .15s;
}
.cta:hover{background:var(--accent);transform:translateY(-1px)}

.empty{text-align:center;color:var(--ink-soft);padding:50px 0 30px;font-size:1.05rem}

/* ===== prose sections ===== */
.prose-section{padding:72px 0}
.prose-section.alt{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.prose-section h2{font-family:"Fraunces",serif;font-weight:600;font-size:clamp(1.7rem,3.5vw,2.3rem);letter-spacing:-.02em;margin-bottom:22px}
.prose-section p{color:var(--ink-soft);font-size:1.06rem;margin-bottom:18px}
.prose-section strong{color:var(--ink);font-weight:600}
.prose-section h3{font-family:"Fraunces",serif;font-weight:600;font-size:1.35rem;letter-spacing:-.01em;margin:34px 0 16px}
.feature-list{list-style:none;display:grid;gap:14px}
.feature-list li{position:relative;padding-left:28px;color:var(--ink-soft);font-size:1.04rem}
.feature-list li::before{content:"→";position:absolute;left:0;top:0;color:var(--accent);font-weight:700}

/* visually hidden, screen-reader only */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* faq */
.faq details{border-bottom:1px solid var(--line);}
.faq details:first-child{border-top:1px solid var(--line)}
.faq summary{
  cursor:pointer;padding:20px 0;font-family:"Fraunces",serif;font-weight:500;font-size:1.15rem;
  list-style:none;display:flex;justify-content:space-between;align-items:center;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:1.5rem;font-family:"Hanken Grotesk",sans-serif;transition:transform .2s}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 0 22px;color:var(--ink-soft)}

/* ===== footer ===== */
.footer{border-top:1px solid var(--line);padding:36px 0}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;color:var(--ink-soft);font-size:.9rem}
.footer a{color:var(--accent-dark);text-decoration:none;font-weight:600}
.footer a:hover{color:var(--accent)}
.footer-links{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.link-btn{
  font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;
  background:none;border:0;padding:0;color:var(--accent-dark);transition:color .2s;
}
.link-btn:hover{color:var(--accent)}

/* ===== contact modal ===== */
.modal-overlay{
  position:fixed;inset:0;z-index:100;
  display:grid;place-items:center;padding:20px;
  background:rgba(26,23,20,.45);backdrop-filter:blur(4px);
  animation:overlay-in .2s ease both;
}
.modal-overlay[hidden]{display:none}
.modal{
  position:relative;width:100%;max-width:480px;
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:34px 30px 30px;
  box-shadow:var(--shadow-hover);
  animation:modal-in .25s cubic-bezier(.2,.7,.2,1) both;
}
.modal-close{
  position:absolute;top:14px;right:16px;
  width:34px;height:34px;border:0;border-radius:9px;cursor:pointer;
  background:none;color:var(--ink-soft);font-size:1.6rem;line-height:1;
  transition:background .2s,color .2s;
}
.modal-close:hover{background:var(--bg);color:var(--ink)}
.modal h2{font-family:"Fraunces",serif;font-weight:600;font-size:1.7rem;letter-spacing:-.02em}
.modal-sub{color:var(--ink-soft);font-size:.98rem;margin:8px 0 22px}

.field{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}
.field label{font-size:.85rem;font-weight:600;color:var(--ink)}
.field input,.field textarea{
  font-family:inherit;font-size:1rem;color:var(--ink);
  background:var(--bg);border:1px solid var(--line-strong);border-radius:10px;
  padding:11px 14px;outline:0;transition:border-color .2s,box-shadow .2s;resize:vertical;
}
.field input:focus,.field textarea:focus{
  border-color:var(--accent);box-shadow:0 0 0 4px rgba(224,83,47,.12)
}
.field input:user-invalid,.field textarea:user-invalid{border-color:#d14343}

.cf-submit{width:100%;text-align:center;align-self:stretch;margin-top:10px;border:0;cursor:pointer;font-family:inherit}

@keyframes overlay-in{from{opacity:0}to{opacity:1}}
@keyframes modal-in{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  .modal-overlay,.modal{animation:none}
}

/* ===== entrance animation ===== */
.card{opacity:0;transform:translateY(14px);animation:rise .6s cubic-bezier(.2,.7,.2,1) forwards}
.card:nth-child(1){animation-delay:.03s}.card:nth-child(2){animation-delay:.06s}
.card:nth-child(3){animation-delay:.09s}.card:nth-child(4){animation-delay:.12s}
.card:nth-child(5){animation-delay:.15s}.card:nth-child(6){animation-delay:.18s}
.card:nth-child(7){animation-delay:.21s}.card:nth-child(8){animation-delay:.24s}
.card:nth-child(9){animation-delay:.27s}.card:nth-child(10){animation-delay:.30s}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.card{animation:none;opacity:1;transform:none}}

/* ===== responsive ===== */
@media (max-width:600px){
  .topnav{display:none}
  .hero{padding:48px 0 36px}
  .container{padding:0 20px}
}
