/* Toolify — Neumorphism × Glassmorphism theme (all colors from CSS variables set by admin) */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:'Inter',system-ui,sans-serif;font-size:16px;line-height:1.6;
  color:var(--text);background:var(--bg);
  background-image:radial-gradient(1200px 600px at 85% -10%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 60%),
                   radial-gradient(900px 500px at -10% 40%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 55%);
  background-attachment:fixed;
}
h1,h2,h3,h4{font-family:'Sora',sans-serif;line-height:1.22;margin:0 0 .5em}
h1{font-size:clamp(1.9rem,4vw,3rem);font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(1.4rem,2.6vw,2rem);font-weight:700}
a{color:var(--primary);text-decoration:none}
img{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 22px}

/* ---------- Core surfaces ---------- */
.neu{background:var(--surface);border-radius:var(--radius);
  box-shadow:9px 9px 20px var(--sd),-9px -9px 20px var(--sl)}
.neu-sm{background:var(--surface);border-radius:calc(var(--radius) - 6px);
  box-shadow:5px 5px 12px var(--sd),-5px -5px 12px var(--sl)}
.neu-inset{background:var(--surface);border-radius:calc(var(--radius) - 6px);
  box-shadow:inset 4px 4px 9px var(--sd),inset -4px -4px 9px var(--sl)}
.glass{background:color-mix(in srgb, var(--surface) 62%, transparent);
  -webkit-backdrop-filter:blur(16px) saturate(1.35);backdrop-filter:blur(16px) saturate(1.35);
  border:1px solid color-mix(in srgb, var(--sl) 55%, transparent);
  box-shadow:0 10px 34px color-mix(in srgb, var(--sd) 55%, transparent)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;border-radius:0;border-left:0;border-right:0;border-top:0}
.header-inner{display:flex;align-items:center;gap:22px;height:70px}
.brand{display:flex;align-items:center;gap:10px;color:var(--text)}
.brand-logo{height:38px;width:auto}
.brand-mark{width:38px;height:38px;display:grid;place-items:center;font-weight:800;font-family:'Sora';color:var(--primary);font-size:1.15rem}
.brand-name{font-family:'Sora';font-weight:700;font-size:1.15rem}
.main-nav{display:flex;gap:4px;margin-left:6px}
.main-nav a{color:var(--text);padding:9px 14px;border-radius:12px;font-weight:500;transition:.18s}
.main-nav a:hover{background:color-mix(in srgb, var(--primary) 12%, transparent);color:var(--primary)}
.header-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.header-search input{border:0;background:transparent;padding:9px 14px;color:var(--text);outline:none;width:170px;font:inherit;font-size:.9rem}
.nav-toggle{display:none;flex-direction:column;gap:4px;padding:11px;border:0;cursor:pointer}
.nav-toggle span{width:18px;height:2px;background:var(--text);border-radius:2px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:14px;border:0;cursor:pointer;
  font:600 .92rem 'Inter';transition:.18s;min-height:44px}
.btn-primary{color:#fff;background:linear-gradient(135deg,var(--primary),color-mix(in srgb, var(--primary) 70%, var(--accent)));
  box-shadow:5px 5px 14px var(--sd),-4px -4px 12px var(--sl)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:7px 9px 18px var(--sd),-4px -4px 12px var(--sl)}
.btn-ghost{background:var(--surface);color:var(--text);box-shadow:5px 5px 12px var(--sd),-5px -5px 12px var(--sl)}
.btn-ghost:hover{color:var(--primary)}
.btn:active{box-shadow:inset 4px 4px 9px var(--sd),inset -4px -4px 9px var(--sl);transform:none}

/* ---------- Hero ---------- */
.hero{padding:74px 0 50px;text-align:center}
.hero .eyebrow{display:inline-block;padding:7px 16px;border-radius:999px;font-size:.82rem;font-weight:600;color:var(--primary);margin-bottom:18px}
.hero p.lead{max-width:640px;margin:0 auto 30px;color:var(--muted);font-size:1.12rem}
.hero-search{max-width:560px;margin:0 auto;display:flex;padding:7px;border-radius:20px}
.hero-search input{flex:1;border:0;background:transparent;padding:12px 18px;font:inherit;color:var(--text);outline:none}
.hero-stats{display:flex;gap:14px;justify-content:center;margin-top:34px;flex-wrap:wrap}
.hero-stats .stat{padding:14px 26px;text-align:center}
.hero-stats b{display:block;font-family:'Sora';font-size:1.35rem;color:var(--primary)}
.hero-stats span{font-size:.82rem;color:var(--muted)}

/* ---------- Sections & grids ---------- */
.section{padding:46px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:26px}
.section-head p{color:var(--muted);margin:4px 0 0}
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Cards ---------- */
.tool-card{padding:26px;display:flex;flex-direction:column;gap:10px;color:var(--text);transition:.2s;position:relative}
.tool-card:hover{transform:translateY(-5px)}
.tool-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;font-size:1.5rem;
  color:var(--primary);box-shadow:inset 4px 4px 9px var(--sd),inset -4px -4px 9px var(--sl)}
.tool-card h3{margin:6px 0 0;font-size:1.08rem}
.tool-card p{color:var(--muted);font-size:.9rem;margin:0;flex:1}
.tool-card .card-meta{display:flex;justify-content:space-between;font-size:.78rem;color:var(--muted)}
.badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.75rem;font-weight:600;
  color:var(--accent);background:color-mix(in srgb, var(--accent) 13%, transparent)}
.cat-card{padding:24px;text-align:center;color:var(--text);transition:.2s}
.cat-card:hover{transform:translateY(-4px);color:var(--primary)}
.cat-card .tool-icon{margin:0 auto 12px}
.post-card{overflow:hidden;color:var(--text);transition:.2s;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-5px)}
.post-card .cover{aspect-ratio:16/9;object-fit:cover;width:100%;display:block}
.post-card .cover-ph{aspect-ratio:16/9;background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 30%, var(--surface)),color-mix(in srgb,var(--accent) 30%, var(--surface)))}
.post-card .body{padding:20px 22px 24px}
.post-card p{color:var(--muted);font-size:.9rem}
.post-card .meta{font-size:.78rem;color:var(--muted)}

/* ---------- Tool page ---------- */
.tool-hero{padding:44px 0 8px}
.breadcrumbs{font-size:.82rem;color:var(--muted);margin-bottom:14px}
.breadcrumbs a{color:var(--muted)}
.tool-layout{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start;padding:26px 0 50px}
.tool-stage{padding:30px}
.tool-stage .tool-embed{min-height:120px}
.tool-sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:90px}
.side-box{padding:20px 22px}
.side-box h4{margin-bottom:10px}
.side-box .mini-list a{display:flex;gap:10px;align-items:center;padding:8px 0;color:var(--text);font-size:.9rem;border-bottom:1px solid color-mix(in srgb,var(--sd) 40%,transparent)}
.side-box .mini-list a:last-child{border:0}
.tool-content{margin-top:34px}

/* ---------- Prose (block editor output) ---------- */
.prose{max-width:760px}
.prose p{color:color-mix(in srgb, var(--text) 88%, var(--muted))}
.prose h2,.prose h3{margin-top:1.6em}
.prose blockquote{margin:1.4em 0;padding:18px 22px;border-left:4px solid var(--primary);
  background:color-mix(in srgb, var(--primary) 7%, transparent);border-radius:0 14px 14px 0}
.prose blockquote cite{display:block;margin-top:8px;color:var(--muted);font-size:.85rem}
.prose pre{padding:18px;overflow:auto;font-size:.88rem}
.prose .table-wrap{overflow:auto}
.prose table{width:100%;border-collapse:collapse;margin:1.2em 0}
.prose th,.prose td{padding:10px 14px;text-align:left;border-bottom:1px solid color-mix(in srgb,var(--sd) 55%,transparent)}
.prose th{font-family:'Sora';font-size:.85rem}
.prose .block-hr{border:0;height:1px;background:color-mix(in srgb,var(--sd) 70%,transparent);margin:2em 0}
.prose figure{margin:1.6em 0}
.prose figure img{border-radius:var(--radius);box-shadow:9px 9px 20px var(--sd),-9px -9px 20px var(--sl)}
.prose figcaption{text-align:center;color:var(--muted);font-size:.84rem;margin-top:8px}
.embed-wrap{position:relative;padding-top:56.25%;border-radius:var(--radius);overflow:hidden;margin:1.5em 0}
.embed-wrap iframe{position:absolute;inset:0;width:100%;height:100%}
.callout{padding:16px 20px;border-radius:14px;background:color-mix(in srgb, var(--accent) 10%, transparent);margin:1.2em 0}
.checklist{list-style:none;padding:0}
.checklist li{padding:6px 0 6px 30px;position:relative}
.checklist li::before{content:'○';position:absolute;left:4px;color:var(--muted)}
.checklist li.done::before{content:'●';color:var(--accent)}

/* ---------- Forms ---------- */
.form-card{max-width:460px;margin:56px auto;padding:36px}
.form-card.wide{max-width:640px}
label{display:block;font-weight:600;font-size:.88rem;margin:16px 0 7px}
.input, textarea.input, select.input{width:100%;border:0;padding:13px 16px;font:inherit;color:var(--text);outline:none;
  background:var(--surface);border-radius:14px;box-shadow:inset 4px 4px 9px var(--sd),inset -4px -4px 9px var(--sl)}
.input:focus{box-shadow:inset 4px 4px 9px var(--sd),inset -4px -4px 9px var(--sl),0 0 0 2px color-mix(in srgb,var(--primary) 55%, transparent)}
.form-foot{margin-top:22px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.muted{color:var(--muted)}
.flash{padding:14px 20px;border-radius:14px;margin:18px 0;font-weight:500}
.flash-success{color:var(--accent)}
.flash-error{color:#e0526b}

/* ---------- Dashboard ---------- */
.dash{display:grid;grid-template-columns:240px 1fr;gap:26px;padding:40px 0 60px;align-items:start}
.dash-side{padding:20px;display:flex;flex-direction:column;gap:6px}
.dash-side a{padding:11px 14px;border-radius:12px;color:var(--text);font-weight:500}
.dash-side a.active,.dash-side a:hover{background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary)}
.dash-main{padding:28px}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:26px}
.stat-card{padding:20px;text-align:center}
.stat-card b{display:block;font-family:'Sora';font-size:1.6rem;color:var(--primary)}
.history-item{display:flex;justify-content:space-between;align-items:center;padding:14px 4px;border-bottom:1px solid color-mix(in srgb,var(--sd) 45%,transparent)}
.history-item:last-child{border:0}
.history-item time{color:var(--muted);font-size:.82rem}

/* ---------- Misc ---------- */
.ad-slot{max-width:1180px;margin:14px auto;padding:0 22px;text-align:center}
.site-footer{margin-top:60px;padding:54px 0 0;background:color-mix(in srgb, var(--surface) 70%, var(--bg));
  border-top:1px solid color-mix(in srgb,var(--sl) 60%,transparent)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:34px;padding-bottom:34px}
.footer-col h4{font-size:.95rem;margin-bottom:14px}
.footer-col a{display:block;color:var(--muted);padding:5px 0;font-size:.9rem}
.footer-col a:hover{color:var(--primary)}
.footer-about{color:var(--muted);font-size:.9rem}
.footer-bottom{border-top:1px solid color-mix(in srgb,var(--sd) 40%,transparent);padding:20px 22px;color:var(--muted);font-size:.85rem;text-align:center}
.pagination{display:flex;gap:10px;justify-content:center;margin:34px 0}
.pagination a,.pagination span{min-width:42px;height:42px;display:grid;place-items:center;border-radius:12px;color:var(--text)}
.pagination .current{color:var(--primary);box-shadow:inset 4px 4px 9px var(--sd),inset -4px -4px 9px var(--sl)}
.empty{padding:50px;text-align:center;color:var(--muted)}

@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}
@media (max-width:960px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .tool-layout{grid-template-columns:1fr}
  .tool-sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .dash{grid-template-columns:1fr}
  .header-search{display:none}
}
@media (max-width:640px){
  .grid-3,.grid-4{grid-template-columns:1fr}
  .main-nav{display:none;position:absolute;top:70px;left:0;right:0;flex-direction:column;padding:16px;
    background:color-mix(in srgb, var(--surface) 92%, transparent);backdrop-filter:blur(16px)}
  .main-nav.open{display:flex}
  .nav-toggle{display:flex}
  .stat-row{grid-template-columns:1fr}
  .header-actions .btn-ghost{display:none}
}
