/* macdetect.com — design system (ported from the approved Claude design) */

:root{
  --bg:#1A1C2D; --card:#242638; --border:#2D3148; --text:#E8EEF8; --text2:#98A2C0;
  --blue:#2563EB; --blueHi:#3B82F6; --teal:#33E0B6; --codebg:#161826; --hover:#2A2D44;
  --ring:rgba(59,130,246,.35); --shadow:0 8px 30px rgba(0,0,0,.35);
  --mono:'Fira Code',ui-monospace,Menlo,Consolas,monospace;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
html[data-theme="light"]{
  --bg:#F8FAFC; --card:#FFFFFF; --border:#E2E8F0; --text:#0F172A; --text2:#64748B;
  --blue:#2563EB; --blueHi:#1D4ED8; --teal:#0DB08A; --codebg:#F1F5F9; --hover:#F1F5F9;
  --ring:rgba(37,99,235,.22); --shadow:0 8px 30px rgba(15,23,42,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg)}
body{color:var(--text);font-family:var(--sans);min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
input,button{font-family:inherit}
input:focus{outline:none}
.mono{font-family:var(--mono)}
@keyframes cardIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.container{max-width:1180px;margin:0 auto;padding:0 20px}
.container-narrow{max-width:760px;margin:0 auto;padding:0 20px}
.main{flex:1;width:100%}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--border)}
.header-inner{max-width:1180px;margin:0 auto;padding:0 20px;height:60px;display:flex;align-items:center;gap:20px}
.logo{display:flex;align-items:center;gap:8px;flex:none}
.logo-badge{width:26px;height:26px;border-radius:7px;background:var(--blue);display:grid;place-items:center;color:#fff;font:700 13px var(--mono)}
.logo-text{font-weight:800;font-size:16px;letter-spacing:-.02em}
.logo-text .tld{color:var(--teal)}
.nav{display:flex;gap:2px;overflow-x:auto;flex:1;min-width:0;scrollbar-width:none}
.nav::-webkit-scrollbar{display:none}
.nav-link{flex:none;padding:6px 10px;border-radius:7px;font-size:12.5px;font-weight:500;color:var(--text2);white-space:nowrap}
.nav-link:hover{background:var(--hover)}
.nav-link.active{color:var(--text);background:var(--hover)}
.header-actions{display:flex;gap:8px;flex:none;align-items:center}
.hbtn{height:32px;padding:0 10px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text2);font:600 11.5px var(--mono);cursor:pointer;display:grid;place-items:center}
.hbtn.icon{width:32px;padding:0}
.hbtn:hover{color:var(--text);border-color:var(--text2)}

/* ---------- buttons ---------- */
.btn{height:34px;padding:0 14px;border-radius:9px;font-size:12.5px;font-weight:600;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--blue);color:#fff;border:none}
.btn-primary:hover{background:var(--blueHi)}
.btn-outline{background:var(--card);color:var(--text);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--text2)}
.btn-lg{height:38px;padding:0 16px;font-size:13px}

/* ---------- hero + search ---------- */
.hero{max-width:760px;margin:0 auto;padding:64px 0 8px;text-align:center}
.badge-live{display:inline-flex;align-items:center;gap:7px;padding:5px 12px;border-radius:99px;border:1px solid var(--border);background:var(--card);font:500 11.5px var(--mono);color:var(--text2);margin-bottom:22px}
.badge-live .dot{width:6px;height:6px;border-radius:99px;background:var(--teal)}
.hero h1{margin:0 0 12px;font-size:clamp(30px,5vw,44px);font-weight:800;letter-spacing:-.03em;line-height:1.1}
.hero-sub{margin:0 auto 32px;max-width:520px;font-size:15.5px;line-height:1.6;color:var(--text2)}
.search-wrap{position:relative;text-align:left}
.search-box{display:flex;align-items:center;gap:12px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:0 18px;height:64px;box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s}
.search-box.focused{border-color:var(--blueHi);box-shadow:0 0 0 4px var(--ring),var(--shadow)}
.search-input{flex:1;min-width:0;border:none;background:transparent;color:var(--text);font:500 clamp(15px,2.6vw,19px) var(--mono);letter-spacing:.01em}
.search-clear{flex:none;width:26px;height:26px;border-radius:99px;border:none;background:var(--hover);color:var(--text2);cursor:pointer;font-size:13px;line-height:1}
.search-hints{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}
.hint{flex:1;min-width:180px;font:500 12px var(--mono);color:var(--text2)}
.hint.valid{color:var(--teal)}

/* ---------- result card ---------- */
.result-card{max-width:760px;margin:28px auto 0;animation:cardIn .25s ease}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.result-head{padding:24px 24px 20px;display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}
.avatar{border-radius:13px;display:grid;place-items:center;color:#fff;font:700 22px var(--sans);flex:none;width:52px;height:52px}
.avatar.lg{width:64px;height:64px;border-radius:16px;font-size:28px}
.avatar.sm{width:28px;height:28px;border-radius:8px;font-size:12px}
.avatar.md{width:56px;height:56px;border-radius:14px;font-size:24px}
.result-head-main{flex:1;min-width:220px}
.eyebrow{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.vendor-name{font-size:24px;font-weight:800;letter-spacing:-.02em;line-height:1.15}
a.vendor-name:hover{color:var(--blueHi)}
.vendor-sub{margin-top:6px;font-size:13px;color:var(--text2)}
.result-actions{display:flex;gap:8px;flex:none}
.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:var(--border);border-top:1px solid var(--border)}
.cell{background:var(--card);padding:14px 24px}
.cell-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.cell-val{font:500 14px var(--mono);padding:5px 0}
.oui-chip{font:600 15px var(--mono);background:var(--codebg);border:1px solid var(--border);border-radius:7px;padding:5px 10px;color:var(--text);cursor:pointer}
.oui-chip:hover{border-color:var(--text2)}
.oui-chip.copied{color:var(--teal)}
.perma{font:500 12.5px var(--mono);color:var(--blueHi);display:inline-block;padding:5px 0;word-break:break-all}
.perma:hover{text-decoration:underline}
.result-cta{display:flex;align-items:center;justify-content:space-between;padding:13px 24px;border-top:1px solid var(--border);color:var(--blueHi);font-size:13.5px;font-weight:600}
.result-cta:hover{background:var(--hover)}

/* badges */
.badge{display:inline-block;font:600 12px var(--mono);padding:5px 10px;border-radius:7px}
.badge-mal{background:rgba(37,99,235,.16);color:var(--blueHi)}
.badge-mam{background:rgba(51,224,182,.14);color:var(--teal)}
.badge-mas{background:rgba(234,179,8,.15);color:#EAB308}

.notfound-card{max-width:760px;margin:28px auto 0;animation:cardIn .25s ease}
.notfound-inner{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px 24px;display:flex;gap:12px;align-items:flex-start}

/* ---------- tools grid ---------- */
.section{max-width:1180px;margin:0 auto;padding:64px 0 0}
.section-title{margin:0 0 4px;font-size:22px;font-weight:800;letter-spacing:-.02em}
.section-sub{margin:0 0 22px;font-size:14px;color:var(--text2)}
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.tool-card{display:block;background:var(--card);border:1px solid var(--border);border-radius:13px;padding:18px;color:var(--text);transition:border-color .15s}
.tool-card:hover{border-color:var(--blueHi)}
.tool-icon{width:36px;height:36px;border-radius:10px;background:var(--codebg);border:1px solid var(--border);display:grid;place-items:center;margin-bottom:12px}
.tool-name{font-size:14.5px;font-weight:700;display:flex;align-items:center;gap:8px}
.new-badge{font:600 9.5px var(--mono);color:var(--teal);border:1px solid var(--teal);border-radius:5px;padding:1px 5px}
.tool-desc{margin-top:5px;font-size:12.5px;line-height:1.5;color:var(--text2)}

/* ---------- ads ---------- */
.ad{border:1px dashed var(--border);border-radius:10px;display:grid;place-items:center;color:var(--text2);font:500 11px var(--mono);background:var(--card)}
.ad-728{max-width:760px;margin:56px auto 0;height:96px}
.ad-300{height:250px}
.ad-970{height:70px;background:var(--bg)}
.ad.ad-filled{border:none;height:auto;min-height:0;background:transparent;display:block;padding:0}
/* AdSense responsive <ins> must have a real width or it errors "availableWidth=0" */
.ad ins.adsbygoogle{display:block!important;width:100%!important;min-width:250px}

/* ---------- prose / faq ---------- */
.prose{max-width:760px;margin:0 auto;padding:56px 0 72px}
.prose p{margin:0 0 8px;font-size:14.5px;line-height:1.7;color:var(--text2)}
.prose p+h2{margin-top:36px}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 18px;border:none;background:transparent;color:var(--text);font-size:14px;font-weight:600;text-align:left;cursor:pointer}
.faq-q:hover{background:var(--hover)}
.faq-item summary{list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item[open] .faq-q .chev{transform:rotate(180deg)}
.faq-q .chev{transition:transform .15s}
.faq-q .chev{color:var(--text2);font-size:12px;flex:none}
.faq-a{padding:0 18px 16px;font-size:13.5px;line-height:1.65;color:var(--text2)}

/* ---------- breadcrumbs ---------- */
.crumbs{font-size:12.5px;color:var(--text2);margin-bottom:22px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.crumbs a:hover{color:var(--text)}
.crumbs .here{color:var(--text);font-weight:600}

/* ---------- vendor page ---------- */
.section-pad{max-width:1180px;margin:0 auto;padding:28px 20px 72px}
.vp-head{display:flex;gap:16px;align-items:center;margin-bottom:22px;flex-wrap:wrap}
.vp-head h1{margin:0;font-size:clamp(22px,3.5vw,30px);font-weight:800;letter-spacing:-.02em}
.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:28px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.stat-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.08em}
.stat-num{margin-top:6px;font:700 24px var(--mono);color:var(--teal)}
.stat-val{margin-top:8px;font:600 14px var(--mono)}
.vgrid{display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start}
.table-card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;min-width:0}
.table-top{padding:14px 16px;border-bottom:1px solid var(--border)}
.table-input{width:100%;height:38px;border:1px solid var(--border);border-radius:9px;background:var(--codebg);color:var(--text);font:500 13px var(--mono);padding:0 12px}
.thead,.trow{display:grid;grid-template-columns:1.4fr .8fr 1fr .5fr;align-items:center}
.thead{padding:10px 16px;border-bottom:1px solid var(--border);background:var(--codebg)}
.th{border:none;background:none;color:var(--text2);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;text-align:left;padding:0}
.th:hover{color:var(--text)}
.trow{padding:11px 16px;border-bottom:1px solid var(--border)}
.trow:hover{background:var(--hover)}
.trow .prefix{font:600 13.5px var(--mono)}
.trow .date{font:500 12.5px var(--mono);color:var(--text2)}
.row-copy{justify-self:end;border:1px solid var(--border);background:transparent;color:var(--text2);border-radius:7px;height:28px;padding:0 10px;font-size:11px;font-weight:600;cursor:pointer}
.row-copy:hover{border-color:var(--text2)}
.badge-sm{font:600 10.5px var(--mono);padding:3px 8px;border-radius:6px}
.table-empty{padding:24px 16px;font-size:13px;color:var(--text2);text-align:center}
.sidebar{display:flex;flex-direction:column;gap:16px}
.side-card{background:var(--card);border:1px solid var(--border);border-radius:13px;padding:16px}
.side-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text2);margin-bottom:10px}
.mini-input{width:100%;height:40px;border:1px solid var(--border);border-radius:9px;background:var(--codebg);color:var(--text);font:500 13px var(--mono);padding:0 12px}
.mini-hint{margin-top:8px;font-size:11.5px;color:var(--text2)}
.related-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:9px;color:var(--text)}
.related-item:hover{background:var(--hover)}
.related-name{flex:1;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.related-count{font:500 11px var(--mono);color:var(--text2)}

/* ---------- mac result page ---------- */
.mac-hero{text-align:center;margin-bottom:26px}
.mac-kicker{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.mac-hero h1{margin:0;font:700 clamp(20px,4.5vw,32px) var(--mono);letter-spacing:.01em}
.mac-accent{height:5px;background:linear-gradient(90deg,var(--blue),var(--teal))}
.mac-actions{display:flex;gap:10px;padding:18px 28px;border-top:1px solid var(--border);flex-wrap:wrap}
.mac-actions .spacer{margin-left:auto}
.center-link{text-align:center;margin-top:24px}
.center-link a{font-size:13.5px;font-weight:600;color:var(--blueHi)}
.center-link a:hover{text-decoration:underline}

/* ---------- directory ---------- */
.az{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:22px}
.az a{width:34px;height:34px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--border);background:var(--card);font:600 12px var(--mono);color:var(--text2)}
.az a:hover,.az a.active{border-color:var(--blueHi);color:var(--text)}
.dir-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.dir-item{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px 14px;background:var(--card);border:1px solid var(--border);border-radius:11px;color:var(--text)}
.dir-item:hover{border-color:var(--blueHi)}
.dir-item .n{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dir-item .c{font:500 11px var(--mono);color:var(--text2);flex:none}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--border);background:var(--card)}
.footer-cols{max-width:1180px;margin:0 auto;padding:36px 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:28px}
.footer-title{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text2);margin-bottom:12px}
.footer-col .links{display:flex;flex-direction:column;gap:8px}
.footer-link{font-size:13px;color:var(--text2)}
.footer-link:hover{color:var(--text)}
.footer-bottom{border-top:1px solid var(--border)}
.footer-bottom-inner{max-width:1180px;margin:0 auto;padding:16px 20px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:center}
.footer-bottom-inner span{font-size:12px;color:var(--text2)}
.footer-bottom-inner .stamp{font:500 11px var(--mono)}

/* ---------- misc ---------- */
.stub-wrap{max-width:760px;margin:0 auto;padding:80px 20px;text-align:center}
.stub-wrap h1{font-size:26px;font-weight:800;margin:0 0 10px}
.stub-wrap p{color:var(--text2);font-size:14.5px}

@media(max-width:760px){
  .vgrid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}
