/*
Theme Name: Mizban Abi
Theme URI: https://example.com/mizban-abi
Author: Your Company
Author URI: https://example.com
Description: قالب حرفه‌ای و سریع وردپرس مخصوص شرکت‌های هاستینگ، ثبت دامنه، سرور مجازی، سرور اختصاصی، خدمات ابری و دیتاسنتر. سازگار با ووکامرس و المنتور، سئوشده و بهینه برای Core Web Vitals.
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.6
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: mizban-abi
Tags: hosting, e-commerce, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, rtl-language-support, translation-ready, threaded-comments, block-styles, wide-blocks
*/

/* =====================================================
   DESIGN TOKENS — light (blueline / drafting-paper) theme
   ===================================================== */
:root{
  --bg-deep:#EEF2F6;
  --bg-panel:#FFFFFF;
  --bg-panel-2:#F6F9FB;
  --line:#DCE3EA;
  --line-soft:#E3E9EF;
  --ink:#101720;
  --muted:#5C6774;
  --muted-dim:#8A96A3;
  --signal:#1D6FE0;
  --signal-dim:#AFCBF2;
  --warn:#B8720A;
  --ok:#1F9D6C;
  --radius:10px;
  --maxw:1240px;
  --mono:'JetBrains Mono', monospace;
  --face:'Vazirmatn', sans-serif;
}

/* =====================================================
   RESET & BASE
   ===================================================== */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg-deep);
  color:var(--ink);
  font-family:var(--face);
  line-height:1.7;
  overflow-x:hidden;
  margin:0;
  background-image:
    linear-gradient(var(--line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size:64px 64px;
  background-position:center top;
}
img{max-width:100%; height:auto; display:block;}
a{color:inherit; text-decoration:none;}
ul{margin:0; padding:0;}
.ltr{direction:ltr; unicode-bidi:isolate; font-family:var(--mono);}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}

/* Accessibility: skip link */
.skip-link{
  position:absolute; right:-9999px; top:0; z-index:999;
  background:var(--signal); color:#fff; padding:10px 18px; border-radius:0 0 8px 8px;
  font-size:14px;
}
.skip-link:focus{right:0;}

.screen-reader-text{
  position:absolute !important; width:1px; height:1px; overflow:hidden;
  clip:rect(1px,1px,1px,1px); white-space:nowrap;
}

.eyebrow{
  font-family:var(--mono); font-size:12px; letter-spacing:.14em;
  color:var(--signal); text-transform:uppercase; display:flex; align-items:center; gap:8px;
}
.eyebrow::before{content:''; width:6px; height:6px; background:var(--signal); border-radius:1px; display:inline-block; box-shadow:0 0 8px var(--signal);}

/* =====================================================
   HEADER / SITE NAV
   ===================================================== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(238,242,246,.86); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding:16px 28px; max-width:var(--maxw); margin:0 auto; gap:24px;}
.logo{display:flex; align-items:center; gap:10px; font-weight:800; font-size:19px;}
.logo img{max-height:34px; width:auto;}
.logo .mark{width:30px; height:30px; position:relative; flex-shrink:0;}
.logo .mark svg{width:100%; height:100%;}
.logo .accent{color:var(--signal);}

.primary-menu-toggle{
  display:none; align-items:center; justify-content:center;
  width:40px; height:40px; border:1px solid var(--line); border-radius:8px;
  background:var(--bg-panel); cursor:pointer;
}
.primary-menu-toggle svg{width:20px; height:20px;}

.navlinks{display:flex; gap:32px; font-size:14.5px; color:var(--muted); list-style:none;}
.navlinks li{position:relative;}
.navlinks a{position:relative; padding:4px 0; transition:color .2s; display:inline-block;}
.navlinks a:hover, .navlinks .current-menu-item > a{color:var(--ink);}
.navlinks a::after{content:''; position:absolute; bottom:-2px; right:0; width:0; height:1px; background:var(--signal); transition:width .25s;}
.navlinks a:hover::after, .navlinks .current-menu-item > a::after{width:100%;}

/* dropdown submenus */
.navlinks ul{
  list-style:none; position:absolute; top:100%; right:0; min-width:200px;
  background:var(--bg-panel); border:1px solid var(--line); border-radius:8px;
  padding:8px; box-shadow:0 16px 32px rgba(16,23,32,.12);
  opacity:0; visibility:hidden; transform:translateY(6px); transition:.2s; z-index:70;
}
.navlinks li:hover > ul{opacity:1; visibility:visible; transform:translateY(0);}
.navlinks ul li a{padding:8px 10px; border-radius:6px; width:100%;}
.navlinks ul li a:hover{background:var(--bg-panel-2);}
.navlinks ul li a::after{display:none;}

/* mega menu */
.navlinks li.has-mega-menu{position:relative;}
.mega-panel{
  position:absolute; top:100%; right:50%; transform:translateX(50%) translateY(6px);
  width:min(860px, 90vw); background:var(--bg-panel); border:1px solid var(--line);
  border-radius:12px; padding:28px; box-shadow:0 24px 48px rgba(16,23,32,.14);
  opacity:0; visibility:hidden; transition:.2s; z-index:70;
}
.navlinks li.has-mega-menu:hover > .mega-panel{opacity:1; visibility:visible; transform:translateX(50%) translateY(0);}
.mega-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:28px;}
.mega-col{display:flex; flex-direction:column; gap:6px;}
.mega-col-title{font-size:14.5px; font-weight:700; color:var(--ink);}
.mega-col-title:hover{color:var(--signal);}
.mega-col-desc{font-size:12.5px; color:var(--muted); margin:0;}
.mega-col-links{list-style:none; margin-top:6px; display:flex; flex-direction:column; gap:6px;}
.mega-col-links a{font-size:13.5px; color:var(--muted); padding:2px 0;}
.mega-col-links a:hover{color:var(--signal);}

@media (max-width:960px){ .mega-grid{grid-template-columns:repeat(2,1fr);} }

.navcta{display:flex; align-items:center; gap:14px; flex-shrink:0;}

.btn{
  display:inline-flex; align-items:center; gap:8px; justify-content:center;
  padding:10px 20px; border-radius:6px; font-size:14.5px; font-weight:600;
  cursor:pointer; border:1px solid transparent; transition:.2s;
}
.btn-primary{background:var(--signal); color:#FFFFFF;}
.btn-primary:hover{background:#1558B8; box-shadow:0 6px 18px rgba(29,111,224,.28);}
.btn-ghost{border-color:var(--line); color:var(--ink); background:transparent;}
.btn-ghost:hover{border-color:var(--signal);}
.btn-sm{padding:7px 14px; font-size:13px;}

@media (max-width:960px){
  .navlinks{display:none;}
  .primary-menu-toggle{display:flex;}
  .navlinks.is-open{
    display:flex; flex-direction:column; position:fixed; inset:0; top:73px;
    background:var(--bg-deep); padding:24px 28px; gap:4px; z-index:60;
    overflow-y:auto;
  }
  .navlinks.is-open a{padding:14px 0; font-size:16px; border-bottom:1px solid var(--line);}
  /* On mobile there's no hover, so nested menus and mega panels are shown
     inline (static, single column) right under their parent link instead
     of relying on :hover — otherwise they'd be permanently unreachable. */
  .navlinks.is-open ul{
    position:static; opacity:1; visibility:visible; transform:none; border:none;
    box-shadow:none; padding:0 0 0 16px; display:block;
  }
  .navlinks.is-open .mega-panel{
    position:static; opacity:1; visibility:visible; transform:none; border:none;
    box-shadow:none; width:auto; padding:0 0 12px; background:transparent;
  }
  .navlinks.is-open .mega-grid{grid-template-columns:1fr; gap:18px; padding-right:16px;}
}

/* =====================================================
   GENERIC SECTION / CARD PRIMITIVES (reused across templates)
   ===================================================== */
section{padding:96px 0;}
.sec-head{max-width:640px; margin-bottom:52px;}
.sec-head h2{font-size:34px; font-weight:800; margin-top:12px; letter-spacing:-.01em;}
.sec-head p{color:var(--muted); font-size:16px; margin-top:12px;}

.panel{background:var(--bg-panel); border:1px solid var(--line); border-radius:var(--radius);}

/* =====================================================
   FOOTER
   ===================================================== */
.site-footer{border-top:1px solid var(--line); padding-top:64px; background:var(--bg-panel); margin-top:64px;}
.foot-grid{display:grid; grid-template-columns:1.4fr repeat(4,1fr); gap:32px; padding-bottom:48px;}
.foot-col h5{font-size:13px; color:var(--muted-dim); font-family:var(--mono); text-transform:uppercase; letter-spacing:.06em; margin-bottom:16px;}
.foot-col ul{list-style:none;}
.foot-col a{display:block; font-size:14px; color:var(--muted); margin-bottom:11px; transition:.2s;}
.foot-col a:hover{color:var(--ink);}
.foot-brand p{color:var(--muted); font-size:13.5px; margin-top:14px; max-width:280px;}

.footer-nav{border-top:1px solid var(--line); padding:16px 0;}
.footer-menu{list-style:none; display:flex; flex-wrap:wrap; gap:24px; justify-content:center;}
.footer-menu a{font-size:13px; color:var(--muted);}
.footer-menu a:hover{color:var(--signal);}

.status-bar{border-top:1px solid var(--line); padding:18px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px;}
.status-ok{display:flex; align-items:center; gap:8px; font-size:12.5px; font-family:var(--mono); color:var(--ok);}
.status-ok .dot{width:6px; height:6px; border-radius:50%; background:var(--ok); box-shadow:0 0 6px var(--ok);}
.copyright{font-size:12.5px; color:var(--muted-dim);}

@media (max-width:960px){
  .foot-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:600px){
  .foot-grid{grid-template-columns:1fr;}
  .status-bar{flex-direction:column; align-items:flex-start;}
}

/* =====================================================
   WORDPRESS CORE MARKUP (alignment, captions, galleries)
   ===================================================== */
.alignwide{margin-right:calc(50% - 50vw); margin-left:calc(50% - 50vw); max-width:1400px; width:auto;}
.alignfull{margin-right:calc(50% - 50vw); margin-left:calc(50% - 50vw); max-width:none; width:100vw;}
.wp-caption, .wp-block-image figcaption{font-size:13px; color:var(--muted); text-align:center; margin-top:8px;}
.wp-block-quote{border-right:3px solid var(--signal); padding-right:20px; color:var(--muted);}

/* =====================================================
   FRONT PAGE — HERO
   ===================================================== */
.hero{position:relative; padding:96px 0 80px; overflow:hidden;}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center;}
.hero h1{font-size:52px; font-weight:800; line-height:1.22; letter-spacing:-.01em; margin-bottom:22px;}
.hero h1 .accent{color:var(--signal);}
.hero p.lead{color:var(--muted); font-size:17.5px; max-width:520px; margin-bottom:32px;}
.hero-ctas{display:flex; gap:14px; margin-bottom:40px; flex-wrap:wrap;}
.hero-stats{display:flex; gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; width:fit-content;}
.hstat{padding:14px 22px; border-left:1px solid var(--line);}
.hstat:last-child{border-left:none;}
.hstat .num{font-family:var(--mono); font-size:20px; font-weight:700; color:var(--ok);}
.hstat .num.warn{color:var(--warn);}
.hstat .num.signal{color:var(--signal);}
.hstat .lbl{font-size:11.5px; color:var(--muted-dim); margin-top:2px;}

.schematic{position:relative; aspect-ratio:1/1; max-width:480px; margin:0 auto;}
.schematic svg{width:100%; height:100%; overflow:visible;}
.crosshair-label{font-family:var(--mono); font-size:10px; fill:var(--muted-dim); letter-spacing:.05em;}
.rack-glow{filter:drop-shadow(0 0 18px rgba(29,111,224,.18));}
@keyframes pulseDot{0%,100%{opacity:1;} 50%{opacity:.25;}}
.pulse{animation:pulseDot 2.4s ease-in-out infinite;}
.dataflow{stroke-dasharray:6 8; animation:flow 1.6s linear infinite;}
@keyframes flow{to{stroke-dashoffset:-28;}}
.readout-card{
  position:absolute; bottom:-18px; right:-18px;
  background:var(--bg-panel); border:1px solid var(--line); border-radius:8px;
  padding:14px 16px; width:190px; box-shadow:0 16px 32px rgba(16,23,32,.1);
}
.readout-card .rc-title{font-size:11px; color:var(--muted-dim); font-family:var(--mono); margin-bottom:8px; display:flex; align-items:center; gap:6px;}
.rc-title .dot{width:6px; height:6px; border-radius:50%; background:var(--ok); box-shadow:0 0 6px var(--ok);}
.rc-row{display:flex; justify-content:space-between; font-size:12.5px; padding:3px 0; color:var(--muted);}
.rc-row b{font-family:var(--mono); color:var(--ink); font-weight:600;}

@media (prefers-reduced-motion: reduce){
  .pulse, .dataflow{animation:none;}
}

/* =====================================================
   TRUST STRIP
   ===================================================== */
.trust{border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:26px 0; background:var(--bg-panel);}
.trust .wrap{display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:20px;}
.trust-label{font-size:13px; color:var(--muted-dim); font-family:var(--mono); white-space:nowrap;}
.trust-logos{display:flex; gap:36px; flex-wrap:wrap; opacity:.65;}
.tlogo{font-weight:700; font-size:15px; color:var(--muted); letter-spacing:.02em;}

/* =====================================================
   SERVICES GRID
   ===================================================== */
.services-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;}
.service-card{background:var(--bg-panel); padding:30px 26px; transition:.2s;}
.service-card:hover{background:var(--bg-panel-2);}
.service-icon{width:38px; height:38px; margin-bottom:18px; color:var(--signal);}
.service-card h3{font-size:18px; font-weight:700; margin-bottom:10px;}
.service-card p{font-size:14px; color:var(--muted); margin-bottom:18px; min-height:66px;}
.specs{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px;}
.service-link{font-size:13.5px; color:var(--signal); display:inline-flex; align-items:center; gap:6px; font-weight:600;}

/* =====================================================
   PRICING
   ===================================================== */
.pricing-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.plan{background:var(--bg-panel); border:1px solid var(--line); border-radius:var(--radius); padding:30px; position:relative; display:flex; flex-direction:column;}
.plan.featured{border-color:var(--signal); box-shadow:0 0 0 1px var(--signal), 0 24px 48px rgba(29,111,224,.08);}
.plan-badge{position:absolute; top:-12px; right:26px; background:var(--signal); color:#FFFFFF; font-size:11.5px; font-weight:700; padding:4px 12px; border-radius:20px;}
.plan h3{font-size:15px; color:var(--muted); font-family:var(--mono); text-transform:uppercase; letter-spacing:.06em; margin-bottom:14px;}
.plan .price{font-size:36px; font-weight:800; font-family:var(--mono); margin-bottom:2px;}
.plan .price span{font-size:14px; color:var(--muted-dim); font-weight:500;}
.plan .price-sub{font-size:12.5px; color:var(--muted-dim); margin-bottom:26px;}
.plan-specs{list-style:none; margin-bottom:28px; flex:1;}
.plan-specs li{display:flex; justify-content:space-between; padding:10px 0; border-top:1px solid var(--line-soft); font-size:13.5px; color:var(--muted);}
.plan-specs li:first-child{border-top:none;}
.plan-specs li b{font-family:var(--mono); color:var(--ink); font-weight:600;}

/* =====================================================
   INFRASTRUCTURE MAP
   ===================================================== */
.map-panel{background:var(--bg-panel); border:1px solid var(--line); border-radius:var(--radius); padding:40px; position:relative; overflow:hidden;}
.map-panel svg{width:100%; height:auto; display:block;}
.node-label{font-family:var(--mono); font-size:10px; fill:var(--muted);}
.node-city{font-size:11px; fill:var(--ink); font-weight:600;}

/* =====================================================
   FEATURES
   ===================================================== */
.features-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line); border-right:1px solid var(--line);}
.feature{padding:28px 24px; border-left:1px solid var(--line); border-bottom:1px solid var(--line);}
.feature .fi{width:26px; height:26px; color:var(--warn); margin-bottom:14px;}
.feature h4{font-size:15.5px; font-weight:700; margin-bottom:8px;}
.feature p{font-size:13px; color:var(--muted);}

/* =====================================================
   TESTIMONIALS
   ===================================================== */
.testi-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.testi{background:var(--bg-panel); border:1px solid var(--line); border-radius:var(--radius); padding:26px;}
.testi .ticket{font-family:var(--mono); font-size:11px; color:var(--muted-dim); margin-bottom:16px; display:flex; justify-content:space-between;}
.testi p{font-size:14.5px; color:var(--ink); margin-bottom:18px;}
.testi .author{display:flex; align-items:center; gap:10px; font-size:13px; color:var(--muted);}
.avatar{width:32px; height:32px; border-radius:50%; background:linear-gradient(135deg, var(--signal), var(--signal-dim)); flex-shrink:0; overflow:hidden;}
.avatar img{width:100%; height:100%; object-fit:cover;}

/* =====================================================
   CTA BANNER
   ===================================================== */
.cta-banner{position:relative; border:1px solid var(--line); border-radius:16px; padding:64px 48px; text-align:center; overflow:hidden; background:var(--bg-panel);}
.cta-banner .corner{position:absolute; width:22px; height:22px; border:1.5px solid var(--signal); opacity:.5;}
.corner.tl{top:18px; right:18px; border-left:none; border-bottom:none;}
.corner.tr{top:18px; left:18px; border-right:none; border-bottom:none;}
.corner.bl{bottom:18px; right:18px; border-left:none; border-top:none;}
.corner.br{bottom:18px; left:18px; border-right:none; border-top:none;}
.cta-banner h2{font-size:32px; font-weight:800; margin:14px 0 14px;}
.cta-banner p{color:var(--muted); margin-bottom:32px; font-size:15.5px;}
.cta-actions{display:flex; gap:14px; justify-content:center; flex-wrap:wrap;}

@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr;}
  .services-grid, .pricing-grid, .testi-grid{grid-template-columns:1fr;}
  .features-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:640px){
  .hero h1{font-size:36px;}
  .readout-card{position:static; width:100%; margin-top:20px;}
}
.wrap-narrow{max-width:760px;}

.archive-head{padding-bottom:0;}
.archive-description{color:var(--muted); font-size:16px; margin-top:12px;}
.archive-body{padding-top:48px;}

.blog-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:24px;
}
.post-card{
  background:var(--bg-panel); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column; transition:.2s;
}
.post-card:hover{border-color:var(--signal-dim); box-shadow:0 16px 32px rgba(16,23,32,.08);}
.post-card-image{display:block; aspect-ratio:16/10; overflow:hidden; background:var(--bg-panel-2);}
.post-card-image img{width:100%; height:100%; object-fit:cover;}
.post-card-body{padding:22px; display:flex; flex-direction:column; gap:10px; flex:1;}
.post-card-title{font-size:18px; font-weight:700; line-height:1.5;}
.post-card-title a:hover{color:var(--signal);}
.post-card-excerpt{font-size:14px; color:var(--muted); flex:1;}

.entry-meta{display:flex; align-items:center; gap:8px; font-size:12.5px; color:var(--muted-dim); font-family:var(--mono); flex-wrap:wrap;}
.entry-meta .meta-sep{opacity:.5;}

.pagination-nav{margin-top:48px; display:flex; justify-content:center;}
.pagination-nav .nav-links{display:flex; gap:8px; align-items:center;}
.pagination-nav .page-numbers{
  font-family:var(--mono); font-size:13.5px; padding:9px 14px; border:1px solid var(--line);
  border-radius:6px; color:var(--muted); background:var(--bg-panel);
}
.pagination-nav .page-numbers.current{background:var(--signal); color:#fff; border-color:var(--signal);}
.pagination-nav .page-numbers:hover{border-color:var(--signal);}
.no-results{padding:48px; text-align:center; color:var(--muted);}

@media (max-width:960px){ .blog-grid{grid-template-columns:repeat(2,1fr);} }
@media (max-width:640px){ .blog-grid{grid-template-columns:1fr;} }

/* =====================================================
   SINGLE POST
   ===================================================== */
.entry-header{padding:64px 0 32px;}
.entry-title{font-size:38px; font-weight:800; line-height:1.3; margin:14px 0 16px; letter-spacing:-.01em;}
.entry-thumbnail{margin-bottom:48px;}
.entry-thumbnail img{border-radius:var(--radius); border:1px solid var(--line);}

.entry-content{font-size:17px; color:var(--ink);}
.entry-content > *{margin-bottom:24px;}
.entry-content h2{font-size:26px; font-weight:800; margin-top:48px; letter-spacing:-.01em;}
.entry-content h3{font-size:21px; font-weight:700; margin-top:36px;}
.entry-content p{color:var(--ink); line-height:1.85;}
.entry-content a{color:var(--signal); text-decoration:underline; text-decoration-color:var(--signal-dim);}
.entry-content ul, .entry-content ol{padding-right:22px; color:var(--ink);}
.entry-content li{margin-bottom:8px;}
.entry-content img{border-radius:var(--radius);}
.entry-content blockquote{
  border-right:3px solid var(--signal); padding:4px 20px; color:var(--muted); font-size:16.5px;
}
.entry-content code{
  font-family:var(--mono); background:var(--bg-panel-2); padding:2px 6px; border-radius:4px; font-size:14px;
}
.entry-content pre{
  font-family:var(--mono); background:var(--bg-panel-2); border:1px solid var(--line);
  border-radius:8px; padding:18px; overflow-x:auto; direction:ltr; text-align:left; font-size:13.5px;
}
.entry-content pre code{background:none; padding:0;}
.entry-content table{width:100%; border-collapse:collapse; font-size:14.5px;}
.entry-content table th, .entry-content table td{border:1px solid var(--line); padding:10px 12px; text-align:right;}
.entry-content table th{background:var(--bg-panel-2); font-family:var(--mono); font-size:12.5px;}

.page-links{font-family:var(--mono); font-size:13px; color:var(--muted); display:flex; gap:8px; align-items:center; flex-wrap:wrap;}

.post-tags{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:36px;}
.spec-chip{
  font-family:var(--mono); font-size:11px; color:var(--muted); border:1px solid var(--line);
  padding:4px 9px; border-radius:4px; display:inline-block;
}
.spec-chip:hover{border-color:var(--signal); color:var(--signal);}

.author-box{
  display:flex; gap:18px; padding:24px; margin-bottom:40px; align-items:flex-start;
}
.author-box img{border-radius:50%; flex-shrink:0;}
.author-box-label{font-family:var(--mono); font-size:11px; color:var(--muted-dim); text-transform:uppercase; letter-spacing:.06em;}
.author-box-name{font-size:16px; font-weight:700; margin:4px 0 8px;}
.author-box p{font-size:14px; color:var(--muted); margin:0;}

.post-nav{
  display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:56px;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:24px 0;
}
.post-nav-next{text-align:left;}
.post-nav a{display:flex; flex-direction:column; gap:6px;}
.post-nav-label{font-family:var(--mono); font-size:11.5px; color:var(--muted-dim);}
.post-nav-title{font-size:14.5px; font-weight:600; color:var(--ink);}
.post-nav a:hover .post-nav-title{color:var(--signal);}
@media (max-width:640px){ .post-nav{grid-template-columns:1fr;} .post-nav-next{text-align:right;} }

.related-posts{margin-bottom:56px;}
.related-posts h3{font-size:22px; font-weight:800; margin-bottom:24px;}
.blog-grid-related{grid-template-columns:repeat(3,1fr);}
@media (max-width:960px){ .blog-grid-related{grid-template-columns:1fr; } }

/* =====================================================
   COMMENTS
   ===================================================== */
.comments-area{margin-bottom:64px;}
.comments-title{font-size:22px; font-weight:800; margin-bottom:28px;}

.comment-list{list-style:none;}
.comment-list .children{list-style:none; padding-right:44px; margin-top:16px;}

.comment-card{padding:22px; margin-bottom:16px;}
.comment-author-row{display:flex; align-items:center; gap:12px; margin-bottom:12px;}
.comment-author-row img{border-radius:50%; flex-shrink:0;}
.comment-author{font-size:14.5px; font-weight:700;}
.comment-date{font-size:12px; color:var(--muted-dim); font-family:var(--mono);}
.comment-content p{font-size:14.5px; color:var(--muted); margin-bottom:10px;}
.comment-awaiting-moderation{font-size:13px; color:var(--warn); font-style:italic; margin-bottom:10px;}
.comment-reply a{font-size:13px; color:var(--signal); font-weight:600;}
.no-comments{color:var(--muted); font-size:14px;}

.comment-form{padding:28px; margin-top:8px;}
.comment-form p{margin-bottom:16px;}
.comment-form label{display:block; font-size:13.5px; font-weight:600; margin-bottom:6px;}
.comment-form .required{color:var(--warn);}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea{
  width:100%; padding:11px 14px; border:1px solid var(--line); border-radius:6px;
  background:var(--bg-panel-2); color:var(--ink); font-family:var(--face); font-size:14.5px;
}
.comment-form textarea{resize:vertical;}
.comment-form input:focus, .comment-form textarea:focus{outline:none; border-color:var(--signal);}
.comment-form .comment-form-cookies-consent{display:flex; align-items:center; gap:8px;}
.comment-form .comment-form-cookies-consent label{margin-bottom:0; font-weight:400;}
.comment-notes, .logged-in-as{font-size:13px; color:var(--muted); margin-bottom:16px;}
#cancel-comment-reply-link{font-size:13px; color:var(--muted); margin-right:12px;}

/* =====================================================
   SEARCH FORM & SEARCH RESULTS
   ===================================================== */
.search-form{display:flex; gap:10px;}
.search-form .search-field{
  flex:1; padding:11px 16px; border:1px solid var(--line); border-radius:6px;
  background:var(--bg-panel); color:var(--ink); font-family:var(--face); font-size:14.5px;
}
.search-form .search-field:focus{outline:none; border-color:var(--signal);}
.search-form .search-submit{
  padding:11px 20px; border-radius:6px; border:none; background:var(--signal); color:#fff;
  font-family:var(--face); font-weight:600; font-size:14.5px; cursor:pointer;
}
.search-form .search-submit:hover{background:#1558B8;}
.search-main .sec-head h1 span{color:var(--signal);}

/* =====================================================
   404
   ===================================================== */
.error-404-hero{padding-bottom:56px;}
.error-404-code{
  font-family:var(--mono); font-size:96px; font-weight:700; color:var(--line);
  -webkit-text-stroke:2px var(--signal); letter-spacing:.05em; margin:8px 0;
}
.error-404-links{padding-top:0; padding-bottom:96px; display:flex; justify-content:center;}
.error-404-readout{position:static; width:260px;}

/* =====================================================
   SIDEBAR / WIDGETS
   ===================================================== */
.page-with-sidebar{display:grid; grid-template-columns:2.2fr 1fr; gap:48px; align-items:start;}
.page-with-sidebar .entry-content{margin-bottom:0;}
@media (max-width:900px){
  .page-with-sidebar{grid-template-columns:1fr;}
}

.widget-area{display:flex; flex-direction:column; gap:20px; position:sticky; top:100px;}
.widget{padding:22px;}
.widget-title{font-size:15px; font-weight:700; margin-bottom:16px; padding-bottom:12px; border-bottom:1px solid var(--line);}
.widget ul{list-style:none;}
.widget li{padding:8px 0; font-size:14px; color:var(--muted); border-bottom:1px solid var(--line-soft);}
.widget li:last-child{border-bottom:none;}
.widget a{color:var(--muted);}
.widget a:hover{color:var(--signal);}
.widget select{
  width:100%; padding:9px 12px; border:1px solid var(--line); border-radius:6px;
  background:var(--bg-panel-2); color:var(--ink); font-family:var(--face);
}
.widget .tagcloud{display:flex; flex-wrap:wrap; gap:8px;}
.widget .tagcloud a{
  font-family:var(--mono); font-size:11px !important; color:var(--muted); border:1px solid var(--line);
  padding:4px 9px; border-radius:4px; display:inline-block;
}
.widget .tagcloud a:hover{border-color:var(--signal); color:var(--signal);}
.widget table{width:100%; font-size:13px; border-collapse:collapse;}
.widget table caption{font-weight:700; margin-bottom:10px; text-align:right;}
.widget table th, .widget table td{padding:6px; text-align:center; border:1px solid var(--line-soft);}
.widget img{border-radius:8px;}
