/*
Theme Name: Hisn Tools
Theme URI: https://example.com
Author: Your Name
Author URI: https://example.com
Description: A dark, minimal theme for a micro AI tools site (password generator, converters, checkers...). Every tool page runs client-side in the browser — no data ever touches the server. Built to showcase a grid of small, focused tools with a consistent dark/mint identity.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hisn-tools
*/

/* ==========================================================================
   Design tokens
   ========================================================================== */
:root{
  --bg:#0F1220;
  --bg-soft:#12162A;
  --surface:#171B2E;
  --surface2:#1F2440;
  --border: rgba(255,255,255,0.08);
  --accent:#6EE7C0;
  --accent-dim: rgba(110,231,192,0.14);
  --accent2:#FFB86B;
  --danger:#FF6B6B;
  --text:#E9ECF5;
  --muted:#8B90A8;
  --mono:'IBM Plex Mono', monospace;
  --disp:'Cairo', sans-serif;
  --body:'Tajawal', sans-serif;
  --maxw: 1040px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:
    radial-gradient(1100px 600px at 85% -10%, rgba(110,231,192,0.10), transparent 60%),
    radial-gradient(900px 500px at 10% 10%, rgba(255,184,107,0.07), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family:var(--body);
  min-height:100vh;
  line-height:1.6;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important;}
}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px;}
.screen-reader-text{position:absolute !important; clip:rect(1px,1px,1px,1px); width:1px; height:1px; overflow:hidden;}

:focus-visible{outline:2px solid var(--accent); outline-offset:2px;}

/* ==========================================================================
   Header / brand / nav
   ========================================================================== */
header.site-header{padding:26px 0 10px;}
.header-row{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;}
.brand{display:flex; align-items:center; gap:12px;}
.brand .mark{
  width:42px;height:42px;border-radius:11px;
  background:linear-gradient(155deg, var(--accent), #3FBF95);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px -6px rgba(110,231,192,0.55);
  flex-shrink:0;
}
.brand .mark svg{width:22px;height:22px;}
.brand-text{font-family:var(--disp); font-weight:800; font-size:1.35rem; letter-spacing:0.2px;}
.brand-text span{color:var(--accent); font-family:var(--mono); font-weight:600; font-size:0.85rem; vertical-align:middle; margin-inline-start:6px; border:1px solid var(--border); padding:2px 8px; border-radius:20px; background:var(--surface);}

.primary-nav ul{list-style:none; display:flex; gap:4px; margin:0; padding:0; flex-wrap:wrap;}
.primary-nav a{
  font-family:var(--body); font-weight:700; font-size:0.92rem; color:var(--muted);
  padding:9px 14px; border-radius:10px; transition:color .15s, background .15s;
  display:inline-block;
}
.primary-nav a:hover, .primary-nav .current-menu-item a{color:var(--text); background:var(--surface);}

/* ==========================================================================
   Buttons (shared across tool pages)
   ========================================================================== */
.btn{
  font-family:var(--body); font-weight:700; font-size:0.95rem;
  border:none; border-radius:12px; padding:12px 22px; cursor:pointer;
  display:inline-flex; align-items:center; gap:8px;
  transition:transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.btn:active{transform:scale(0.96);}
.btn-primary{background:var(--accent); color:#0B1F1A; box-shadow:0 10px 24px -10px rgba(110,231,192,0.6);}
.btn-primary:hover{box-shadow:0 14px 28px -10px rgba(110,231,192,0.75);}
.btn-ghost{background:var(--surface2); color:var(--text); border:1px solid var(--border);}
.btn-ghost:hover{background:#262c4d;}

/* ==========================================================================
   Hero (homepage)
   ========================================================================== */
.hero{padding:34px 0 10px; text-align:center;}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:0.78rem; color:var(--accent);
  background:var(--accent-dim); border:1px solid rgba(110,231,192,0.3);
  padding:6px 14px; border-radius:20px; margin-bottom:20px;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent); animation:pulse 1.8s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1; transform:scale(1);} 50%{opacity:0.4; transform:scale(0.7);}}
h1{
  font-family:var(--disp); font-weight:900; font-size:clamp(1.8rem, 4.4vw, 2.9rem);
  margin:0 0 12px; letter-spacing:-0.5px;
}
h1 em{font-style:normal; color:var(--accent);}
.hero .sub{color:var(--muted); max-width:560px; margin:0 auto 40px; font-size:1.02rem;}

/* ==========================================================================
   Tool cards / grid (homepage + archive)
   ========================================================================== */
.tools-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:0 0 60px;}
@media (max-width:820px){.tools-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.tools-grid{grid-template-columns:1fr;}}

.tool-card{
  background:var(--surface); border:1px solid var(--border); border-radius:16px;
  padding:20px; display:block; text-align:left;
  transition:transform 0.15s, border-color 0.15s;
}
.tool-card:hover{transform:translateY(-3px); border-color:rgba(110,231,192,0.35);}
.tool-card .icon{
  width:38px; height:38px; border-radius:10px; background:var(--accent-dim);
  color:var(--accent); display:flex; align-items:center; justify-content:center;
  margin-bottom:14px; font-size:1.1rem; overflow:hidden;
}
.tool-card .icon img{width:100%; height:100%; object-fit:cover; border-radius:10px;}
.tool-card .icon .icon-lib{
  width:100%; height:100%; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  color:var(--accent); font-weight:800; font-size:1.15rem; line-height:1;
  font-family:var(--disp); background:none;
}
.tool-card .icon .icon-lib i{font-size:1.15rem;}
.tool-card .t{font-weight:700; font-size:1rem; margin-bottom:6px; font-family:var(--disp);}
.tool-card .d{color:var(--muted); font-size:0.85rem; line-height:1.55;}
.tool-card.current{border-color:var(--accent); background:var(--accent-dim);}

.section-head{text-align:center; margin-bottom:28px;}
.section-head h2{font-family:var(--disp); font-size:1.4rem; margin:0 0 8px;}
.section-head .sub2{color:var(--muted); font-size:0.95rem; margin:0;}

/* ==========================================================================
   Single tool page
   ========================================================================== */
.tool-page-head{text-align:center; padding:20px 0 6px;}
.tool-page-head .eyebrow{margin-bottom:16px;}
.tool-page-head h1{font-size:clamp(1.6rem, 3.6vw, 2.3rem);}
.tool-page-head .sub{margin-bottom:30px;}

.tool-body{margin-bottom:20px;}
/* the actual interactive markup for each tool is pasted into the page/CPT
   content by the site admin (buttons, .vault, .options etc. reuse the
   .btn / var(--*) tokens above, so any tool built like the password
   generator will inherit this look automatically). */

.back-link{display:inline-flex; align-items:center; gap:6px; color:var(--muted); font-size:0.9rem; font-weight:700; margin-bottom:18px;}
.back-link:hover{color:var(--accent);}

/* ==========================================================================
   Generic page / post content
   ========================================================================== */
.page-content{max-width:760px; margin:0 auto; padding:20px 0 60px;}
.page-content h1{font-size:clamp(1.6rem,3.4vw,2.3rem); text-align:left;}
.page-content p{color:var(--text); font-size:1rem;}
.page-content a{color:var(--accent); text-decoration:underline;}

/* ==========================================================================
   Footer
   ========================================================================== */
footer.site-footer{border-top:1px solid var(--border); padding:26px 0 40px; margin-top:20px;}
.foot-row{display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; align-items:center; color:var(--muted); font-size:0.82rem;}
.privacy{display:flex; align-items:center; gap:8px; color:var(--accent);}

/* ==========================================================================
   404
   ========================================================================== */
.error-404{text-align:center; padding:80px 0;}
.error-404 .code{font-family:var(--mono); color:var(--accent); font-size:0.9rem; margin-bottom:10px;}
