/*
 * LiteCMS Default Theme — style.css
 * Mobile-first, responsive, no CDN, local Inter font
 * Urdu/RTL support built-in
 */

/* ============================================================
   LOCAL INTER FONT (files placed in themes/default/fonts/)
============================================================ */
@font-face {
  font-family: 'Inter';
  src: url('fonts/inter-regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('fonts/inter-medium.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('fonts/inter-semibold.woff2') format('woff2');
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('fonts/inter-bold.woff2') format('woff2');
  font-weight: 700; font-style: normal; font-display: swap;
}

/* ============================================================
   CSS CUSTOM PROPERTIES
============================================================ */
:root {
  --font-sans:  'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-h1h2:  var(--font-sans);
  --font-h3h4:  var(--font-sans);
  --font-body:  var(--font-sans);
  --font-nav:   var(--font-sans);

  --primary:       #6366f1;
  --primary-dark:  #4f46e5;
  --primary-light: #e0e7ff;
  --accent:        #f59e0b;
  --text:          #1e293b;
  --text-muted:    #64748b;
  --text-light:    #94a3b8;
  --bg:            #ffffff;
  --bg-alt:        #f8fafc;
  --bg-dark:       #0f172a;
  --border:        #e2e8f0;
  --border-dark:   #cbd5e1;
  --success:       #22c55e;
  --error:         #ef4444;

  --container:  1200px;
  --content-w:  740px;
  --gap:        1.5rem;
  --radius:     12px;
  --radius-sm:  6px;
  --radius-lg:  20px;
  --shadow-sm:  0 1px 4px rgba(0,0,0,.06);
  --shadow:     0 4px 16px rgba(0,0,0,.08);
  --shadow-lg:  0 12px 40px rgba(0,0,0,.12);
  --header-h:   64px;
}

/* ============================================================
   RESET & BASE — mobile first
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;}
img,video,svg{max-width:100%;height:auto;display:block;}
a{color:var(--primary);text-decoration:none;}
a:hover{color:var(--primary-dark);}
ul,ol{list-style:none;}
button{cursor:pointer;font-family:inherit;}

/* ============================================================
   RTL BODY
============================================================ */
.rtl-body {direction:rtl;}
.rtl-body .site-nav ul {flex-direction:row-reverse;}
.rtl-body .breadcrumbs {flex-direction:row-reverse;}
.rtl-body .post-card-meta {flex-direction:row-reverse;}

/* ============================================================
   TYPOGRAPHY
============================================================ */
h1,h2{font-family:var(--font-h1h2);font-weight:700;line-height:1.2;letter-spacing:-.3px;}
h3,h4{font-family:var(--font-h3h4);font-weight:700;line-height:1.25;}
h5,h6{font-weight:600;line-height:1.3;}
h1{font-size:clamp(1.75rem,5vw,2.75rem);}
h2{font-size:clamp(1.4rem,4vw,2rem);}
h3{font-size:clamp(1.1rem,3vw,1.4rem);}
h4{font-size:1.05rem;}
p{margin-bottom:1.1rem;}
p:last-child{margin-bottom:0;}

/* ============================================================
   LAYOUT
============================================================ */
.container{max-width:var(--container);margin:0 auto;padding:0 1rem;}
.container-sm{max-width:var(--content-w);margin:0 auto;padding:0 1rem;}
.section{padding:3rem 0;}
.section-sm{padding:2rem 0;}

@media(min-width:768px){
  .container,.container-sm{padding:0 1.5rem;}
  .section{padding:4rem 0;}
  .section-sm{padding:2.5rem 0;}
}
@media(min-width:1024px){
  .section{padding:5rem 0;}
}

/* ============================================================
   HEADER — Pure CSS, no JavaScript
   Mobile menu  : CSS checkbox #nav-toggle
   Search bar   : CSS checkbox #search-toggle
   Desktop dropdowns: CSS :hover
============================================================ */

/* Hidden checkboxes that control state */
.css-toggle { position:absolute;opacity:0;width:0;height:0;pointer-events:none; }

.site-header {
  position: sticky; top: 0; z-index: 500;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.hdr-inner { display:flex;align-items:center;height:var(--header-h);gap:1rem; }

/* Logo */
.site-logo { display:flex;align-items:center;gap:.5rem;text-decoration:none;flex-shrink:0; }
.site-logo img { height:34px;width:auto; }
.site-logo-text { font-size:1.1rem;font-weight:800;color:var(--text);letter-spacing:-.4px;white-space:nowrap; }

/* Desktop nav — hidden on mobile */
.site-nav { display:none; }
@media (min-width:768px) {
  .site-nav { display:flex;align-items:center;flex:1; }
  .nav-list { display:flex;align-items:center;gap:.1rem;list-style:none;margin:0;padding:0; }
  .nav-item { position:relative; }
  .nav-link {
    display:flex;align-items:center;gap:.3rem;height:38px;padding:0 .85rem;
    font-size:.875rem;font-weight:500;color:var(--text-muted);font-family:var(--font-nav);
    text-decoration:none;border-radius:6px;white-space:nowrap;
    transition:color .18s,background .18s;
  }
  .nav-link:hover,.nav-link.active { color:var(--primary);background:var(--primary-light); }
  .nav-link.active { font-weight:600; }
  .nav-arrow { font-size:.65rem;opacity:.6;transition:transform .2s; }
  /* Desktop dropdown — :hover */
  .nav-dropdown {
    display:none;position:absolute;top:calc(100% + 4px);left:0;min-width:200px;
    background:#fff;border:1.5px solid var(--border);border-radius:10px;
    box-shadow:0 8px 24px rgba(0,0,0,.12);list-style:none;padding:.4rem;z-index:600;
  }
  .nav-item:hover > .nav-dropdown { display:block; }
  .nav-item:hover > .nav-link .nav-arrow { transform:rotate(180deg); }
  .nav-dropdown li a {
    display:flex;align-items:center;padding:.52rem .85rem;font-size:.875rem;font-weight:500;
    color:var(--text);text-decoration:none;border-radius:6px;
    transition:background .15s,color .15s;white-space:nowrap;
  }
  .nav-dropdown li a:hover,.nav-dropdown li a.active { background:var(--primary-light);color:var(--primary); }
}

/* Right side */
.hdr-right { display:flex;align-items:center;gap:.4rem;flex-shrink:0;margin-left:auto; }
@media (min-width:768px) { .hdr-right { margin-left:0; } }

/* Search icon label */
.search-label {
  display:flex;align-items:center;justify-content:center;width:36px;height:36px;
  border:1.5px solid var(--border);border-radius:8px;cursor:pointer;
  color:var(--text-muted);transition:all .2s;flex-shrink:0;
}
.search-label:hover { border-color:var(--primary);background:var(--primary-light);color:var(--primary); }
#search-toggle:checked ~ header .search-label { border-color:var(--primary);background:var(--primary-light);color:var(--primary); }

/* Search bar — hidden until #search-toggle checked */
.search-bar-wrap { height:0;overflow:hidden;background:var(--bg-alt);border-top:1px solid transparent;transition:height .25s ease,border-color .25s; }
#search-toggle:checked ~ header .search-bar-wrap { height:60px;border-top-color:var(--border); }
.search-bar-form {
  display:flex;align-items:center;gap:.55rem;height:60px;
  background:#fff;border:1.5px solid var(--border);border-radius:10px;
  padding:0 .85rem;transition:border-color .2s,box-shadow .2s;
}
.search-bar-form:focus-within { border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.12); }
.search-bar-form svg { color:var(--text-muted);flex-shrink:0; }
.search-bar-form input { flex:1;min-width:0;border:none;outline:none;font-size:.95rem;font-family:inherit;color:var(--text);background:transparent; }
.search-bar-form input::placeholder { color:var(--text-light); }
.search-bar-form button[type=submit] {
  background:var(--primary);color:#fff;border:none;border-radius:6px;
  padding:.35rem .95rem;font-size:.82rem;font-weight:600;cursor:pointer;
  white-space:nowrap;font-family:inherit;transition:background .2s;
}
.search-bar-form button[type=submit]:hover { background:var(--primary-dark); }
.search-close-label { cursor:pointer;color:var(--text-muted);font-size:1rem;padding:.2rem .4rem;border-radius:4px;transition:color .15s;line-height:1; }
.search-close-label:hover { color:var(--error); }

/* Hamburger label — mobile only */
.hbg-label {
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;
  width:36px;height:36px;border:1.5px solid var(--border);border-radius:8px;
  cursor:pointer;flex-shrink:0;transition:border-color .2s,background .2s;
}
.hbg-label:hover { border-color:var(--primary);background:var(--primary-light); }
.hbg-label span { display:block;width:18px;height:2px;background:var(--text);border-radius:2px;transition:transform .26s ease,opacity .26s ease; }
#nav-toggle:checked ~ header .hbg-label span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
#nav-toggle:checked ~ header .hbg-label span:nth-child(2) { opacity:0;transform:scaleX(0); }
#nav-toggle:checked ~ header .hbg-label span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
#nav-toggle:checked ~ header .hbg-label { border-color:var(--primary);background:var(--primary-light); }
@media (min-width:768px) { .hbg-label { display:none; } }

/* Mobile overlay — shown when nav-toggle checked */
.nav-overlay-label { display:none;position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:998;cursor:pointer; }
#nav-toggle:checked ~ .nav-overlay-label { display:block; }
@media (min-width:768px) { .nav-overlay-label { display:none!important; } }

/* Mobile drawer */
.mobile-drawer {
  position:fixed;top:0;bottom:0;right:0;width:min(290px,82vw);
  background:var(--bg);z-index:999;overflow-y:auto;display:flex;flex-direction:column;
  transform:translateX(110%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  box-shadow:-4px 0 28px rgba(0,0,0,.16);
}
#nav-toggle:checked ~ .mobile-drawer { transform:translateX(0); }
@media (min-width:768px) { .mobile-drawer { display:none!important; } }

.mdrw-head { display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.1rem;border-bottom:1px solid var(--border);background:var(--bg-alt);flex-shrink:0; }
.mdrw-head strong { font-size:1rem;font-weight:800;color:var(--text); }
.mdrw-close-label { cursor:pointer;border:1.5px solid var(--border);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--text-muted);transition:all .15s;line-height:1; }
.mdrw-close-label:hover { background:var(--error);color:#fff;border-color:var(--error); }
.mdrw-search-wrap { padding:.7rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-alt); }
.mdrw-search-inner { display:flex;align-items:center;gap:.5rem;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:.42rem .75rem; }
.mdrw-search-inner:focus-within { border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.1); }
.mdrw-search-inner svg { color:var(--text-muted);flex-shrink:0; }
.mdrw-search-inner input { flex:1;min-width:0;border:none;outline:none;font-size:.9rem;font-family:inherit;color:var(--text);background:transparent; }
.mdrw-search-inner input::placeholder { color:var(--text-light); }
.mdrw-search-inner button { background:var(--primary);color:#fff;border:none;border-radius:6px;padding:.28rem .7rem;font-size:.85rem;font-weight:700;cursor:pointer;font-family:inherit; }
.mdrw-nav { list-style:none;padding:.4rem 0;margin:0;flex:1; }
.mdrw-item > a { display:flex;align-items:center;padding:.85rem 1.1rem;font-size:.97rem;font-weight:500;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border);transition:background .15s,color .15s; }
.mdrw-item > a:hover { background:var(--primary-light);color:var(--primary); }
/* details/summary sub-menu */
.mdrw-details { border-bottom:1px solid var(--border); }
.mdrw-summary { display:flex;align-items:center;padding:.85rem 1.1rem;cursor:pointer;list-style:none;transition:background .15s; }
.mdrw-summary::-webkit-details-marker { display:none; }
.mdrw-summary:hover { background:var(--primary-light); }
.mdrw-summary > a { flex:1;font-size:.97rem;font-weight:500;color:var(--text);text-decoration:none; }
.mdrw-summary > a:hover { color:var(--primary); }
.mdrw-arrow { font-size:.7rem;color:var(--text-muted);transition:transform .2s;flex-shrink:0;margin-left:.5rem; }
.mdrw-details[open] .mdrw-arrow { transform:rotate(180deg); }
.mdrw-sub { list-style:none;background:var(--bg-alt);padding:.25rem 0; }
.mdrw-sub li a { display:flex;align-items:center;gap:.4rem;padding:.7rem 1.1rem .7rem 1.6rem;font-size:.9rem;font-weight:500;color:var(--text-muted);text-decoration:none;border-bottom:1px solid var(--border);transition:background .15s,color .15s; }
.mdrw-sub li a::before { content:'›';color:var(--primary); }
.mdrw-sub li a:hover { background:var(--primary-light);color:var(--primary); }
.mdrw-sub li:last-child a { border-bottom:none; }



/* ============================================================
   HERO SECTION
============================================================ */
.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#1e1b4b 0%,#312e81 40%,#4c1d95 100%);padding:5rem 0 4rem;text-align:center;color:#fff;}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.18;}
.hero-content{position:relative;z-index:1;}
.hero-tag{display:inline-block;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .9rem;border-radius:100px;margin-bottom:1rem;}
.hero h1{font-size:clamp(1.8rem,5vw,3rem);font-weight:900;color:#fff;margin-bottom:1rem;line-height:1.15;}
.hero p{font-size:1.05rem;color:rgba(255,255,255,.75);max-width:560px;margin:0 auto 1.75rem;}
.hero-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;}
.hero-btn-primary{background:#fff;color:var(--primary);font-weight:700;padding:.75rem 1.75rem;border-radius:100px;text-decoration:none;font-size:.95rem;transition:all .2s;}
.hero-btn-primary:hover{background:rgba(255,255,255,.9);transform:translateY(-1px);}
.hero-btn-secondary{background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.35);color:#fff;font-weight:600;padding:.75rem 1.75rem;border-radius:100px;text-decoration:none;font-size:.95rem;transition:all .2s;}
.hero-btn-secondary:hover{background:rgba(255,255,255,.2);}

/* ============================================================
   BUTTONS
============================================================ */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:all .2s;font-family:inherit;text-decoration:none;line-height:1.4;}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--border);}
.btn-ghost:hover{background:var(--bg-alt);border-color:var(--text-muted);}
.btn-sm{padding:.35rem .75rem;font-size:.8rem;}
.btn-danger{background:var(--error);color:#fff;border-color:var(--error);}
.btn-danger:hover{opacity:.88;}

/* ============================================================
   SECTION / LABELS
============================================================ */
.section{padding:3rem 0;}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem;}
.section-title{font-size:1.35rem;font-weight:800;}
.section-label{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:.4rem;}
.view-all{font-size:.85rem;font-weight:600;color:var(--primary);text-decoration:none;}
.view-all:hover{text-decoration:underline;}

/* ============================================================
   FEATURED STRIP
============================================================ */
.featured-strip{padding:0 0 2rem;}
.featured-strip .section-header{margin-bottom:1rem;}
.featured-grid{display:grid;grid-template-columns:1fr;gap:1rem;}
@media(min-width:640px){.featured-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:900px){.featured-grid{grid-template-columns:repeat(3,1fr);}}

/* ============================================================
   POSTS GRID
============================================================ */
.posts-section-header{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;
}
.cat-pills{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;}
.section-heading{font-size:1.35rem;font-weight:800;margin:0;}
.posts-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;}
@media(min-width:540px){.posts-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:900px){.posts-grid{grid-template-columns:repeat(3,1fr);}}

/* ============================================================
   POST CARD
============================================================ */
.post-card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .25s,box-shadow .25s;
  position:relative;cursor:pointer;
}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
/* Full card overlay */
.post-card-link-overlay,.post-card-overlay-link{position:absolute;inset:0;z-index:1;display:block;}
.post-card .cat-badge,.post-card .read-more,.post-card-title a,.post-card-footer{position:relative;z-index:2;}

.post-card-img{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--bg-alt);}
.post-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;}
.post-card:hover .post-card-img img{transform:scale(1.04);}
.cat-badge{
  display:inline-block;background:var(--primary);color:#fff;
  font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  padding:.22rem .6rem;border-radius:100px;text-decoration:none;
  transition:background .2s;
}
.cat-badge:hover{background:var(--primary-dark);color:#fff;text-decoration:none;}
.post-card-img .cat-badge{position:absolute;top:.6rem;left:.6rem;z-index:2;}

.post-card-body{padding:1rem;display:flex;flex-direction:column;flex:1;}
.post-card-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.78rem;color:var(--text-muted);margin-bottom:.45rem;}
.post-card-meta time{color:var(--text-muted);}
.post-card-title{font-size:1rem;font-weight:700;line-height:1.35;margin-bottom:.45rem;}
.post-card-title a{color:var(--text);text-decoration:none;transition:color .18s;}
.post-card-title a:hover{color:var(--primary);}
.post-card-excerpt{font-size:.85rem;color:var(--text-muted);line-height:1.6;flex:1;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.post-card-footer{margin-top:auto;padding-top:.6rem;border-top:1px solid var(--border);}
.read-more{font-size:.82rem;font-weight:700;color:var(--primary);text-decoration:none;transition:color .2s;}
.read-more:hover{color:var(--primary-dark);}
.read-more::after{content:' →';}

/* ============================================================
   CATEGORY GRID (image overlay style)
============================================================ */
.category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;}
@media(min-width:640px){.category-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.category-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;}}

/* ============================================================
   TAGS
============================================================ */
.post-tags{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin:1.5rem 0;}
.tags-label{font-size:.8rem;font-weight:700;color:var(--text-muted);margin-right:.25rem;}
.tag-link{display:inline-block;background:var(--bg-alt);border:1px solid var(--border);color:var(--text-muted);font-size:.78rem;font-weight:500;padding:.22rem .65rem;border-radius:100px;text-decoration:none;transition:all .2s;}
.tag-link:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary);}

/* ============================================================
   SHARE BUTTONS
============================================================ */
.post-share{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin:1.5rem 0;padding:1rem;background:var(--bg-alt);border-radius:var(--radius);border:1px solid var(--border);}
.share-label{font-size:.82rem;font-weight:700;color:var(--text-muted);margin-right:.25rem;flex-shrink:0;}
.share-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.32rem .85rem;border-radius:100px;font-size:.78rem;font-weight:700;color:#fff;text-decoration:none;border:none;cursor:pointer;font-family:inherit;transition:opacity .2s,transform .15s;}
.share-btn:hover{opacity:.88;transform:translateY(-1px);}
.share-twitter{background:#1da1f2;}.share-facebook{background:#1877f2;}
.share-whatsapp{background:#25d366;}.share-telegram{background:#2ca5e0;}
.share-linkedin{background:#0077b5;}.share-copy{background:var(--primary);}

/* ============================================================
   SIDEBAR WIDGETS
============================================================ */
.sidebar-widget{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;margin-bottom:1.25rem;}
.sidebar-widget:last-child{margin-bottom:0;}
.sidebar-widget h4{font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:.85rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);}
.sidebar-post{display:flex;align-items:center;gap:.65rem;text-decoration:none;color:var(--text);padding:.45rem 0;border-bottom:1px solid var(--border);transition:color .18s;}
.sidebar-post:last-child{border-bottom:none;}
.sidebar-post:hover{color:var(--primary);}
.sidebar-post img{width:52px;height:52px;object-fit:cover;border-radius:6px;flex-shrink:0;}
.sidebar-no-img{width:52px;height:52px;background:var(--primary-light);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.sidebar-post-text{font-size:.82rem;font-weight:600;line-height:1.4;}
.sidebar-post-text span{display:block;font-size:.74rem;font-weight:400;color:var(--text-muted);margin-top:.2rem;}

/* ============================================================
   CATEGORY ARCHIVE
============================================================ */
.archive-header{background:var(--bg-alt);border-bottom:1px solid var(--border);padding:2.5rem 0;text-align:center;}
.archive-label{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:.4rem;}
.archive-header h1{margin-bottom:.4rem;}
.archive-header p{color:var(--text-muted);max-width:460px;margin:0 auto;}

.category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;}
@media(min-width:640px){.category-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.category-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;}}

.cat-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:var(--bg-alt);text-decoration:none;display:block;transition:transform .25s,box-shadow .25s;}
.cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.cat-card:hover img{transform:scale(1.05);}
.cat-card-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.65) 0%,transparent 55%);display:flex;align-items:flex-end;padding:1rem;}
.cat-card-overlay h3{color:#fff;font-size:.95rem;}
.cat-card-overlay span{color:rgba(255,255,255,.7);font-size:.78rem;}
.cat-card-no-img{background:linear-gradient(135deg,var(--primary),var(--primary-dark));}

/* ============================================================
   SINGLE POST
============================================================ */
.post-hero{background:var(--bg-alt);border-bottom:1px solid var(--border);padding:2.5rem 0 0;}
.post-header{max-width:var(--content-w);margin:0 auto;padding:0 1rem;}
@media(min-width:640px){.post-header{padding:0 1.5rem;}}
.post-header .post-card-meta{margin-bottom:.9rem;font-size:.875rem;}
.post-header h1{margin-bottom:.75rem;}
.post-header .excerpt{font-size:1.05rem;color:var(--text-muted);margin-bottom:1.25rem;}
.post-featured-img{margin-top:2rem;border-radius:var(--radius) var(--radius) 0 0;overflow:hidden;aspect-ratio:21/8;}
.post-featured-img img{width:100%;height:100%;object-fit:cover;}

.post-layout{
  display:grid;grid-template-columns:1fr;
  gap:2rem;padding:2rem 0;
  max-width:var(--content-w);margin:0 auto;
  padding-left:1rem;padding-right:1rem;
  align-items:start;
}
@media(min-width:640px){.post-layout{padding-left:1.5rem;padding-right:1.5rem;}}
@media(min-width:1024px){
  .post-layout:not(.no-sidebar){
    grid-template-columns:1fr 290px;
    max-width:calc(var(--content-w) + 290px + 2.5rem);
    gap:2.5rem;
    padding:3rem 1.5rem;
    align-items:start;
  }
}

/* Article content */
.post-content{font-size:1.05rem;line-height:1.85;color:var(--text);}
.post-content h2,.post-content h3,.post-content h4{margin:2rem 0 .75rem;}
.post-content p{margin-bottom:1.35rem;}
.post-content ul,.post-content ol{margin:1rem 0 1.35rem 1.5rem;list-style:revert;}
.post-content li{margin-bottom:.4rem;}
.post-content blockquote{border-left:4px solid var(--primary);padding:.75rem 1.1rem;margin:1.5rem 0;background:var(--primary-light);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-muted);font-style:italic;}
.post-content pre{background:var(--bg-dark);color:#a3e635;padding:1.1rem;border-radius:var(--radius-sm);overflow-x:auto;font-size:.875rem;margin:1.5rem 0;}
.post-content code{background:var(--bg-alt);color:var(--primary-dark);padding:.15em .4em;border-radius:3px;font-size:.9em;}
.post-content pre code{background:none;color:inherit;padding:0;}
.post-content img{border-radius:var(--radius-sm);margin:1rem 0;}
.post-content a{text-decoration:underline;text-underline-offset:3px;}
.post-content table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.9rem;}
.post-content th,.post-content td{padding:.65rem;border:1px solid var(--border);text-align:left;}
.post-content th{background:var(--bg-alt);font-weight:600;}

/* RTL post content */
[dir="rtl"] .post-content{text-align:right;}
[dir="rtl"] .post-content ul,[dir="rtl"] .post-content ol{margin-left:0;margin-right:1.5rem;}
[dir="rtl"] .post-content th,[dir="rtl"] .post-content td{text-align:right;}

/* Tags */
.post-tags{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid var(--border);}
.tags-label{font-size:.8rem;font-weight:700;color:var(--text-muted);margin-right:.25rem;}
.tag-link{display:inline-block;background:var(--bg-alt);color:var(--text-muted);font-size:.78rem;font-weight:500;padding:.27rem .7rem;border-radius:100px;border:1px solid var(--border);text-decoration:none;transition:all .2s;}
.tag-link:hover{background:var(--primary);color:#fff;border-color:var(--primary);}

/* Share */
.post-share{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border);}
.share-label{font-weight:600;font-size:.85rem;color:var(--text-muted);}
.share-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .85rem;border-radius:100px;font-size:.8rem;font-weight:600;border:none;cursor:pointer;text-decoration:none;transition:opacity .2s,transform .15s;color:#fff;}
.share-btn:hover{opacity:.88;transform:translateY(-1px);}
.share-twitter{background:#1da1f2;}
.share-facebook{background:#1877f2;}
.share-linkedin{background:#0077b5;}
.share-whatsapp{background:#25d366;}
.share-telegram{background:#2ca5e0;}
.share-copy{background:var(--primary);}

/* Sidebar */
.post-sidebar{position:static;align-self:start;}
@media(min-width:1024px){.post-sidebar{position:sticky;top:calc(var(--header-h) + 1.5rem);align-self:start;}}
.sidebar-widget{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.25rem;}
.sidebar-widget h4{font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.9rem;padding-bottom:.55rem;border-bottom:1px solid var(--border);}
.sidebar-post{display:flex;gap:.7rem;margin-bottom:.85rem;text-decoration:none;color:var(--text);align-items:flex-start;}
.sidebar-post:last-child{margin-bottom:0;}
.sidebar-post img,.sidebar-no-img{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;}
.sidebar-no-img{background:linear-gradient(135deg,#6366f1,#a855f7);display:flex;align-items:center;justify-content:center;font-size:1rem;}
.sidebar-post-text{font-size:.84rem;font-weight:600;line-height:1.35;}
.sidebar-post-text span{font-weight:400;color:var(--text-muted);font-size:.76rem;display:block;margin-top:.2rem;}
.sidebar-post:hover .sidebar-post-text{color:var(--primary);}

/* ============================================================
   BREADCRUMBS
============================================================ */
.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem;font-size:.8rem;color:var(--text-muted);margin-bottom:1.25rem;}
.breadcrumbs a{color:var(--text-muted);text-decoration:none;}
.breadcrumbs a:hover{color:var(--primary);}
.breadcrumbs .sep{color:var(--text-light);}
.breadcrumbs .current{color:var(--text);font-weight:500;}

/* ============================================================
   RELATED POSTS
============================================================ */
.related-posts{padding:2.5rem 0;border-top:1px solid var(--border);}
.related-posts h3{margin-bottom:1.25rem;font-size:1.15rem;}

/* ============================================================
   COMMENTS
============================================================ */
.comments-section{padding:2.5rem 0;background:var(--bg-alt);}
.comment-list{margin-bottom:2.5rem;}
.comment-item{display:flex;gap:.85rem;margin-bottom:1.25rem;}
.comment-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.comment-body{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1.1rem;}
.comment-meta{display:flex;align-items:center;gap:.85rem;margin-bottom:.5rem;}
.comment-meta .name{font-weight:700;font-size:.875rem;}
.comment-meta .date{color:var(--text-muted);font-size:.78rem;}
.comment-text{font-size:.875rem;white-space:pre-line;}
.comment-form h3{margin-bottom:1.25rem;}
.form-row{display:grid;grid-template-columns:1fr;gap:.9rem;}
@media(min-width:540px){.form-row{grid-template-columns:1fr 1fr;}}
.form-group{margin-bottom:1rem;}
.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem;}
.form-group input,.form-group textarea{width:100%;padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.925rem;font-family:inherit;color:var(--text);background:var(--bg);transition:border-color .2s;outline:none;}
.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);}
.form-group textarea{resize:vertical;min-height:120px;}
.hint{font-size:.76rem;color:var(--text-muted);margin-top:.3rem;}
.comment-submit-btn{background:var(--primary);color:#fff;border:none;padding:.7rem 1.75rem;border-radius:100px;font-size:.925rem;font-weight:700;cursor:pointer;transition:background .2s;}
.comment-submit-btn:hover{background:var(--primary-dark);}
.comment-success{background:#f0fdf4;border:1px solid #86efac;border-radius:var(--radius);padding:1.25rem;text-align:center;color:#16a34a;margin-bottom:1.5rem;}
.comment-success h4{margin-bottom:.4rem;}

/* ============================================================
   PAGINATION
============================================================ */
.pagination{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center;margin-top:2.25rem;}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 .65rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;border:1.5px solid var(--border);text-decoration:none;color:var(--text-muted);transition:all .2s;}
.pagination a:hover{border-color:var(--primary);color:var(--primary);}
.pagination .active,.pagination .current{background:var(--primary);border-color:var(--primary);color:#fff;}

/* ============================================================
   STATIC PAGE
============================================================ */
.page-layout{max-width:var(--content-w);margin:0 auto;padding:2.5rem 1rem;}
@media(min-width:640px){.page-layout{padding:3rem 1.5rem;}}
.page-layout.page-full-width{max-width:100%;padding:2.5rem 1rem;}
@media(min-width:640px){.page-layout.page-full-width{padding:3rem 2rem;}}
.page-header{margin-bottom:2rem;}
.page-header h1{margin-bottom:.4rem;}
.page-header .page-meta{color:var(--text-muted);font-size:.85rem;}

/* ============================================================
   404 PAGE
============================================================ */
.page-404{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:3rem 1rem;}
.page-404 .code{font-size:6rem;font-weight:900;color:var(--primary);line-height:1;opacity:.12;}
@media(min-width:640px){.page-404 .code{font-size:9rem;}}
.page-404 .inner{max-width:400px;}
.page-404 h1{margin-bottom:.65rem;}
.page-404 p{color:var(--text-muted);margin-bottom:1.75rem;}

/* ============================================================
   FOOTER
============================================================ */
.site-footer{background:var(--bg-dark);color:rgba(255,255,255,.65);padding:3rem 0 0;}
@media(min-width:768px){.site-footer{padding:4rem 0 0;}}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem;}
@media(min-width:540px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:900px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;}}
.footer-brand .site-logo-text{color:#fff;}
.footer-brand p{font-size:.85rem;margin-top:.6rem;line-height:1.7;color:rgba(255,255,255,.5);}
.footer-col h5{color:#fff;font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.9rem;}
.footer-col li{margin-bottom:.5rem;}
.footer-col a{color:rgba(255,255,255,.52);font-size:.85rem;text-decoration:none;transition:color .2s;}
.footer-col a:hover{color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.25rem 0;display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:rgba(255,255,255,.38);flex-wrap:wrap;gap:.5rem;}
.footer-bottom a{color:rgba(255,255,255,.45);}
.footer-bottom a:hover{color:#fff;}

/* ============================================================
   ALERTS
============================================================ */
.alert{padding:.85rem 1.1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.875rem;}
.alert-success{background:#f0fdf4;color:#16a34a;border:1px solid #86efac;}
.alert-error{background:#fef2f2;color:#dc2626;border:1px solid #fca5a5;}
.alert-info{background:#eff6ff;color:#1d4ed8;border:1px solid #93c5fd;}

/* ============================================================
   NO-IMAGE PLACEHOLDER
============================================================ */
.no-image-placeholder{background:linear-gradient(135deg,var(--primary-light),#ddd6fe);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:2rem;width:100%;height:100%;min-height:160px;}

/* ============================================================
   PRINT
============================================================ */
@media print{
  .site-header,.site-footer,.post-sidebar,.related-posts,.comments-section,.hamburger,#mobileDrawer,#navOverlay{display:none!important;}
  .post-layout{grid-template-columns:1fr!important;}
  body{font-size:12pt;}
}

/* ============================================================
   AUTHOR BOX (below post content)
============================================================ */
.author-box {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  padding: 1.5rem;
  background: var(--bg-alt);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  margin-top: 2rem;
}
.author-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 3px solid var(--border);
}
.author-avatar-placeholder {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), #a855f7);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.75rem;
  font-weight: 800;
  flex-shrink: 0;
}
.author-info { flex: 1; min-width: 0; }
.author-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: .25rem;
}
.author-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: .4rem;
}
.author-bio {
  font-size: .875rem;
  color: var(--text-muted);
  line-height: 1.65;
  margin-bottom: .6rem;
}
.author-social { display: flex; gap: .5rem; flex-wrap: wrap; }
.author-social a {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .78rem;
  font-weight: 600;
  color: var(--primary);
  text-decoration: none;
  padding: .22rem .65rem;
  background: var(--primary-light);
  border-radius: 100px;
  transition: all .2s;
}
.author-social a:hover { background: var(--primary); color: #fff; }

@media (max-width: 480px) {
  .author-box { flex-direction: column; align-items: center; text-align: center; }
  .author-social { justify-content: center; }
}

/* ============================================================
   PAGINATION — SeoHelper generated markup
============================================================ */
.pagination-list {
  display: flex;
  align-items: center;
  gap: .3rem;
  flex-wrap: wrap;
  list-style: none;
  padding: 0; margin: 0;
}
.pagination .pagination-list li a,
.pagination .pagination-list li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px; height: 36px;
  padding: 0 .65rem;
  border-radius: var(--radius-sm);
  font-size: .85rem; font-weight: 600;
  border: 1.5px solid var(--border);
  text-decoration: none;
  color: var(--text-muted);
  transition: all .2s;
  white-space: nowrap;
}
.pagination .pagination-list li a:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-light); }
.pagination .pagination-list li .active,
.pagination .pagination-list li .current { background:var(--primary); border-color:var(--primary); color:#fff; }
.pagination .pagination-list li .disabled { opacity:.4; pointer-events:none; cursor:default; }
.pagination .pagination-list li .pag-ellipsis { border:none; background:none; color:var(--text-muted); min-width:24px; }
.pagination .pagination-list li .pag-prev,
.pagination .pagination-list li .pag-next { padding: 0 1rem; font-size:.82rem; }

/* ============================================================
   AD SLOTS
============================================================ */
.ad-slot {
  margin: 1.5rem auto;
  text-align: center;
  overflow: hidden;
  max-width: 100%;
}
.ad-slot--ads_header_banner { margin: 0 auto; padding: .5rem 0; background: var(--bg-alt); border-bottom: 1px solid var(--border); }
.ad-slot--ads_sidebar_top,
.ad-slot--ads_sidebar_mid { margin: 0 0 1.25rem; }
.ad-slot--ads_before_post_content { margin: 0 0 1.5rem; }
.ad-slot--ads_after_post_content  { margin: 1.5rem 0; }
.ad-slot--ads_home_mid { margin: 0; grid-column: 1 / -1; }

/* Sticky footer ad */
.ad-sticky-footer {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 9000;
  background: rgba(255,255,255,.97);
  border-top: 1px solid var(--border);
  text-align: center;
  padding: .35rem;
  box-shadow: 0 -4px 16px rgba(0,0,0,.1);
}
.ad-sticky-close {
  position: absolute;
  top: 4px; right: 8px;
  background: rgba(0,0,0,.08);
  border: none;
  border-radius: 50%;
  width: 22px; height: 22px;
  font-size: .65rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted);
  transition: background .15s;
  line-height: 1;
}
.ad-sticky-close:hover { background: rgba(0,0,0,.18); }

/* Add bottom padding to page when sticky footer is present */
body:has(.ad-sticky-footer) { padding-bottom: 70px; }

@media print {
  .ad-slot, .ad-sticky-footer { display: none !important; }
}
