/* Noxilo — fast, modern directory styles. No framework. */
*,*::before,*::after{box-sizing:border-box}
:root{
  --bg:#0c0e14;--surface:#151823;--surface-2:#1c2130;--line:#262c3d;
  --text:#e8eaf0;--muted:#9aa3b8;--brand:#7c5cff;--brand-2:#33d9b2;
  --star:#ffc24b;--radius:14px;--maxw:1180px;--shadow:0 6px 24px rgba(0,0,0,.28);
  --grad:linear-gradient(120deg,#7c5cff,#33d9b2);
}
[data-theme="light"]{
  --bg:#f7f8fb;--surface:#fff;--surface-2:#f0f2f7;--line:#e4e8f0;
  --text:#15181f;--muted:#5b6478;--shadow:0 6px 20px rgba(20,30,60,.08);
}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);
  font:16px/1.65 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;background:var(--brand);color:#fff;padding:8px 14px;border-radius:8px;z-index:99}

/* header */
.site-head{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;gap:18px;height:64px}
.brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:1.25rem;letter-spacing:-.02em}
.brand-mark{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:1.3em}
.search{flex:1;display:flex;max-width:520px;margin:0 auto}
.search input{flex:1;background:var(--surface);border:1px solid var(--line);color:var(--text);
  border-radius:10px 0 0 10px;padding:10px 14px;font-size:.95rem;outline:none}
.search input:focus{border-color:var(--brand)}
.search button{border:1px solid var(--line);border-left:0;background:var(--surface-2);
  border-radius:0 10px 10px 0;padding:0 14px;cursor:pointer;color:var(--text)}
.main-nav{display:flex;align-items:center;gap:16px}
.main-nav a{color:var(--muted);font-weight:600;font-size:.95rem}.main-nav a:hover{color:var(--text)}
.theme-toggle{background:var(--surface-2);border:1px solid var(--line);color:var(--text);
  width:38px;height:38px;border-radius:10px;cursor:pointer;font-size:1rem}

/* hero */
.hero{padding:64px 0 40px;text-align:center;background:radial-gradient(900px 380px at 50% -120px,rgba(124,92,255,.18),transparent)}
.hero h1{font-size:clamp(2rem,5vw,3.3rem);line-height:1.1;letter-spacing:-.03em;margin:0 0 14px}
.hero-accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{color:var(--muted);max-width:660px;margin:0 auto 26px;font-size:1.08rem}
.hero-search{display:flex;max-width:560px;margin:0 auto 18px}
.hero-search input{flex:1;background:var(--surface);border:1px solid var(--line);color:var(--text);
  border-radius:12px 0 0 12px;padding:14px 18px;font-size:1rem;outline:none}
.hero-search input:focus{border-color:var(--brand)}
.hero-search button{background:var(--grad);color:#fff;border:0;font-weight:700;padding:0 26px;
  border-radius:0 12px 12px 0;cursor:pointer}
.hero-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:10px}
.chip{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:.88rem;color:var(--muted)}
.chip:hover{border-color:var(--brand);color:var(--text)}

/* sections */
.section{padding:40px 0}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:22px}
.section-head h2{font-size:1.5rem;letter-spacing:-.02em;margin:0}
.see-all{color:var(--brand);font-weight:600;font-size:.95rem}

/* category tiles */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.cat-grid.wide{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.cat-tile{display:flex;flex-direction:column;gap:4px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:16px 18px;transition:.15s}
.cat-tile:hover{border-color:var(--brand);transform:translateY(-2px)}
.cat-name{font-weight:700}.cat-count{color:var(--muted);font-size:.85rem}

/* card grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.15s}
.card:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow)}
.card-thumb{aspect-ratio:16/9;background:var(--surface-2);overflow:hidden}
.card-thumb img{width:100%;height:100%;object-fit:cover}
.card-thumb-ph{width:100%;height:100%;display:grid;place-items:center;font-size:2.4rem;font-weight:800;
  color:#fff;background:var(--grad)}
.card-body{padding:14px 16px}
.card-title{margin:0 0 6px;font-size:1.05rem;letter-spacing:-.01em}
.card-desc{margin:0 0 10px;color:var(--muted);font-size:.9rem;line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-rating{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--muted)}

/* stars */
.stars{color:var(--star);letter-spacing:1px}.star.empty{color:var(--line)}.star.half{position:relative;color:var(--line)}
.star.half::before{content:"★";position:absolute;color:var(--star);width:50%;overflow:hidden}
.rating-num{font-weight:700;color:var(--text)}

/* breadcrumbs */
.crumbs{padding:18px 0 0;color:var(--muted);font-size:.88rem}
.crumbs a{color:var(--muted)}.crumbs a:hover{color:var(--brand)}.crumbs .sep{margin:0 8px;opacity:.5}

/* tool page */
.cat-head{padding:26px 0 8px}.cat-head h1{font-size:clamp(1.7rem,4vw,2.4rem);letter-spacing:-.02em;margin:0 0 10px}
.cat-intro{color:var(--muted);max-width:760px}
.tool{padding-top:8px}
.tool-head{display:flex;gap:22px;align-items:flex-start;padding:18px 0 8px;flex-wrap:wrap}
.tool-logo img,.tool-logo-ph{width:108px;height:108px;border-radius:20px;object-fit:cover;border:1px solid var(--line)}
.tool-logo-ph{display:grid;place-items:center;font-size:3rem;font-weight:800;color:#fff;background:var(--grad)}
.tool-head-main{flex:1;min-width:260px}
.tool-head-main h1{margin:0 0 6px;font-size:clamp(1.7rem,4vw,2.4rem);letter-spacing:-.02em}
.tool-tagline{color:var(--muted);margin:0 0 12px;font-size:1.05rem}
.tool-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;font-size:.9rem}
.tag{background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:4px 12px;color:var(--muted);font-size:.82rem}
.tag:hover{border-color:var(--brand);color:var(--text)}
.btn-visit{display:inline-block;background:var(--grad);color:#fff;font-weight:700;padding:11px 22px;border-radius:11px}
.btn-visit:hover{filter:brightness(1.08)}.btn-visit.full{display:block;text-align:center;margin-top:14px}
.tool-grid{display:grid;grid-template-columns:1fr 300px;gap:36px;margin-top:24px}
.tool-content{min-width:0}
.prose h2{font-size:1.4rem;letter-spacing:-.02em;margin:32px 0 12px}
.prose p{color:var(--text)}.prose ul{padding-left:0;list-style:none}
.feature-list li,.usecase-list li{position:relative;padding:8px 0 8px 28px;border-bottom:1px solid var(--line);color:var(--text)}
.feature-list li::before{content:"✓";position:absolute;left:0;color:var(--brand-2);font-weight:800}
.usecase-list li::before{content:"→";position:absolute;left:0;color:var(--brand);font-weight:800}
.proscons{margin:32px 0}.proscons h2{font-size:1.4rem;margin-bottom:12px}
.pc-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pc{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.pc h3{margin:0 0 8px;font-size:1.05rem}.pc ul{margin:0;padding-left:18px;color:var(--muted)}.pc li{margin:6px 0}
.faq details{border:1px solid var(--line);border-radius:10px;padding:0 16px;margin:10px 0;background:var(--surface)}
.faq summary{cursor:pointer;font-weight:600;padding:14px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--brand);font-weight:800}
.faq details[open] summary::after{content:"–"}
.faq details>div{padding-bottom:14px;color:var(--muted)}
.tool-aside{min-width:0}
.aside-box{position:sticky;top:84px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}
.aside-box h3{margin:0 0 12px}.aside-box dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:8px 14px}
.aside-box dt{color:var(--muted);font-size:.88rem}.aside-box dd{margin:0;text-align:right;font-weight:600}
.related{margin-top:20px}

/* pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:18px;margin:36px 0 0}
.pg{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:9px 18px;font-weight:600}
.pg:hover{border-color:var(--brand)}.pg-info{color:var(--muted);font-size:.9rem}

/* misc */
.seo-intro{max-width:820px}.seo-intro h2{font-size:1.5rem;margin-bottom:12px}
.seo-intro a{color:var(--brand)}.seo-intro p{color:var(--muted)}
.empty{color:var(--muted);text-align:center;padding:40px 0}
.error-page{text-align:center;padding:80px 0}.error-page h1{font-size:2.4rem}

/* footer */
.site-foot{border-top:1px solid var(--line);margin-top:60px;padding:48px 0 28px;background:var(--surface)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px}
.foot-about p{color:var(--muted);max-width:380px;margin-top:10px;font-size:.92rem}
.site-foot h3{font-size:.95rem;margin:0 0 12px}.site-foot ul{list-style:none;padding:0;margin:0}
.site-foot li{margin:7px 0}.site-foot a{color:var(--muted);font-size:.92rem}.site-foot a:hover{color:var(--brand)}
.copyright{color:var(--muted);font-size:.82rem;margin-top:32px;border-top:1px solid var(--line);padding-top:20px}

@media(max-width:860px){.tool-grid{grid-template-columns:1fr}.aside-box{position:static}.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.head-inner{gap:10px}.brand-name{display:none}.main-nav a{display:none}
  .pc-grid{grid-template-columns:1fr}.foot-grid{grid-template-columns:1fr}}
