/* Kutab Nagri — combined stylesheet (tokens + components). Fonts loaded via <link> in head. */
/* Kutab Nagri WordPress theme — design tokens (warm rose / maroon / cream).
   Ported from the Kutab Nagri design system. Self-contained for WP. */

:root {
  /* Neutrals */
  --cream-50:#FDF8F4; --cream-100:#FBF1EA; --cream-200:#F5E7DC;
  --sand-300:#EADBCF; --sand-400:#DCC7B6;
  --ink-900:#2A1A1F; --ink-700:#4C353C; --ink-500:#6F555D; --ink-400:#927A82; --ink-300:#B7A3AA;
  /* Maroon */
  --maroon-900:#4E0F26; --maroon-800:#6E1B38; --maroon-700:#8A2A4C; --maroon-100:#F3DEE6;
  /* Rose */
  --rose-700:#A83A5B; --rose-600:#C24E6E; --rose-500:#D26880; --rose-300:#ECA9BC; --rose-100:#FAE3EA; --rose-50:#FDF1F4;
  /* Gold */
  --gold-600:#B0863A; --gold-500:#C99B49; --gold-300:#E6C988; --gold-100:#F6EBD2;
  /* Semantic */
  --green-600:#2E7D5B; --green-100:#E2F1E9; --amber-600:#BE7B22; --amber-100:#FAEDD6;
  --red-600:#C0392B; --red-100:#FBE5E2; --blue-600:#3A6EA5; --blue-100:#E5EEF7;

  /* Aliases */
  --color-bg:var(--cream-50); --color-bg-band:var(--cream-100);
  --surface-card:#FFFFFF; --surface-sunken:var(--cream-100); --surface-inverse:var(--maroon-900);
  --text-strong:var(--ink-900); --text-body:var(--ink-700); --text-muted:var(--ink-500); --text-faint:var(--ink-400);
  --text-on-brand:#FFF; --text-link:var(--rose-700);
  --brand:var(--maroon-800); --brand-strong:var(--maroon-900); --brand-soft:var(--maroon-100);
  --accent:var(--rose-600); --accent-hover:var(--rose-700); --accent-soft:var(--rose-100);
  --gold:var(--gold-500); --gold-soft:var(--gold-100);
  --border:var(--sand-300); --border-strong:var(--sand-400); --divider:var(--cream-200); --focus-ring:var(--rose-500);
  --success:var(--green-600); --success-soft:var(--green-100); --warning:var(--amber-600); --warning-soft:var(--amber-100);
  --danger:var(--red-600); --danger-soft:var(--red-100); --info:var(--blue-600); --info-soft:var(--blue-100);

  /* Fonts */
  --font-display:"Playfair Display",Georgia,serif;
  --font-body:"Mulish",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,Menlo,monospace;

  /* Scale */
  --text-xs:.75rem; --text-sm:.875rem; --text-base:1rem; --text-md:1.125rem;
  --text-lg:1.375rem; --text-xl:1.75rem; --text-2xl:2.25rem; --text-3xl:2.875rem;
  --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-extrabold:800; --fw-black:900;
  --lh-tight:1.1; --lh-snug:1.25; --lh-normal:1.5; --lh-relaxed:1.7;
  --ls-wider:.12em;

  /* Space */
  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem; --space-5:1.5rem;
  --space-6:2rem; --space-7:2.5rem; --space-8:3rem; --space-9:4rem;
  --container:1200px; --sidebar-w:320px;

  /* Radius + shadow + motion */
  --radius-xs:4px; --radius-sm:8px; --radius-md:12px; --radius-lg:16px; --radius-xl:22px; --radius-pill:999px;
  --shadow-xs:0 1px 2px rgba(78,15,38,.06); --shadow-sm:0 2px 6px rgba(78,15,38,.07);
  --shadow-md:0 8px 20px rgba(78,15,38,.09); --shadow-lg:0 16px 40px rgba(78,15,38,.12); --shadow-xl:0 28px 64px rgba(78,15,38,.16);
  --ring:0 0 0 3px rgba(210,104,128,.35);
  --ease-out:cubic-bezier(.22,.61,.36,1); --dur:200ms; --dur-fast:120ms;
}

/* Kutab Nagri WordPress theme — components & layout. Uses tokens.css vars. */

/* ---- base ---- */
*,*::before,*::after{box-sizing:border-box}
body.kutabnagri{margin:0;background:var(--color-bg);color:var(--text-body);font-family:var(--font-body);font-size:var(--text-base);line-height:var(--lh-relaxed);-webkit-font-smoothing:antialiased}
.kutabnagri h1,.kutabnagri h2,.kutabnagri h3,.kutabnagri h4{font-family:var(--font-display);color:var(--text-strong);line-height:var(--lh-tight);letter-spacing:-.02em;margin:0 0 .5em;font-weight:var(--fw-bold)}
.kutabnagri a{color:var(--text-link);text-decoration:none;transition:color var(--dur) var(--ease-out)}
.kutabnagri a:hover{color:var(--accent-hover)}
.kutabnagri img{max-width:100%;height:auto;display:block}
.bn-wrap{max-width:var(--container);margin-inline:auto;padding-inline:var(--space-5)}
.bn-eyebrow{font-size:var(--text-xs);font-weight:var(--fw-bold);letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--accent);margin:0 0 .4em}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}

/* ---- buttons ---- */
.bn-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--font-body);font-weight:var(--fw-bold);border-radius:var(--radius-md);border:1.5px solid transparent;cursor:pointer;text-decoration:none;font-size:var(--text-base);padding:.7em 1.3em;transition:background var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out),transform var(--dur-fast)}
.bn-btn:active{transform:translateY(1px) scale(.99)}
.bn-btn--primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}
.bn-btn--primary:hover{background:var(--accent-hover);color:#fff;box-shadow:var(--shadow-md)}
.bn-btn--secondary{background:#fff;color:var(--brand);border-color:var(--border-strong)}
.bn-btn--secondary:hover{background:var(--cream-100);border-color:var(--brand);color:var(--brand)}
.bn-btn--gold{background:var(--gold);color:#fff}
.bn-btn--gold:hover{background:var(--gold-600);color:#fff}
.bn-btn--soft{background:#fff;color:var(--brand);border-color:var(--border-strong)}
.bn-btn--soft:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.bn-btn--soft-accent{color:var(--accent);border-color:var(--rose-300)}
.bn-btn--soft-accent:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.bn-btn--lg{padding:.85em 1.6em;font-size:var(--text-md)}
.bn-btn--block{width:100%}
.bn-btn svg{width:18px;height:18px}

/* ---- badges ---- */
.bn-badge{display:inline-flex;align-items:center;gap:.4em;font-weight:var(--fw-bold);font-size:var(--text-xs);line-height:1;padding:.45em .7em;border-radius:var(--radius-pill)}
.bn-badge--accent{background:var(--accent-soft);color:var(--rose-700)}
.bn-badge--brand{background:var(--brand-soft);color:var(--brand)}
.bn-badge--solid{background:var(--accent);color:#fff}
.bn-badge--success{background:var(--success-soft);color:var(--success)}
.bn-badge--success::before{content:"";width:.5em;height:.5em;border-radius:50%;background:currentColor}

/* ---- header ---- */
.bn-header{position:sticky;top:0;z-index:100}
.bn-topbar{background:var(--maroon-900);color:var(--rose-100)}
.bn-topbar__inner{display:flex;align-items:center;justify-content:space-between;height:38px;font-size:var(--text-xs)}
.bn-topbar__inner a{color:var(--rose-100);opacity:.85;display:inline-flex;margin-left:14px}
.bn-topbar__inner a:hover{color:#fff;opacity:1}
.bn-topbar svg{width:15px;height:15px}
.bn-header__main{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);background:#fff;padding:var(--space-4) 0;border-bottom:1px solid var(--divider)}
.bn-header__search{display:flex;gap:8px;width:min(420px,42vw)}
.bn-header__search input[type=search]{flex:1;min-width:0;border:1.5px solid var(--border-strong);border-radius:var(--radius-md);padding:.6em .9em;font-family:inherit;font-size:var(--text-base);background:#fff;color:var(--text-strong)}
.bn-header__search input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.bn-header__search button{flex:none;width:48px;border:none;border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.bn-header__search button:hover{background:var(--accent-hover)}

/* ---- logo ---- */
.bn-logo{display:inline-flex;align-items:center;gap:.6em;text-decoration:none;line-height:1}
.bn-logo__mark{width:44px;height:44px;flex:none;border-radius:11px;background:linear-gradient(150deg,var(--maroon-700),var(--maroon-900));color:var(--cream-50);font-family:var(--font-display);font-weight:900;font-size:22px;display:inline-flex;align-items:center;justify-content:center;position:relative;box-shadow:var(--shadow-sm)}
.bn-logo__mark::after{content:"";position:absolute;left:18%;right:18%;bottom:16%;height:2px;background:var(--gold-300);border-radius:2px}
.bn-logo__word{font-family:var(--font-display);font-weight:var(--fw-bold);font-size:24px;color:var(--text-strong);letter-spacing:-.01em}
.bn-logo__word em{font-style:normal;color:var(--accent)}
.bn-logo__tag{display:block;font-family:var(--font-body);font-weight:var(--fw-semibold);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-top:4px}
.bn-logo--invert .bn-logo__word{color:#fff}
.bn-logo--invert .bn-logo__mark{background:var(--cream-50);color:var(--maroon-900)}

/* ---- nav ---- */
.bn-nav{background:linear-gradient(90deg,var(--maroon-800),var(--maroon-700));box-shadow:var(--shadow-sm)}
.bn-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap}
.bn-nav li{position:relative}
.bn-nav a{display:inline-flex;align-items:center;gap:6px;color:var(--rose-100);font-weight:var(--fw-bold);font-size:var(--text-sm);padding:15px 18px;border-bottom:3px solid transparent;transition:background var(--dur),color var(--dur)}
.bn-nav a:hover{background:rgba(255,255,255,.1);color:#fff}
.bn-nav .current-menu-item>a,.bn-nav .current_page_item>a{color:#fff;border-bottom-color:var(--gold-300);background:rgba(0,0,0,.12)}
.bn-nav .sub-menu{display:none;position:absolute;top:100%;left:0;min-width:230px;background:#fff;border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:var(--shadow-lg);padding:8px;z-index:30}
.bn-nav li:hover>.sub-menu{display:block}
.bn-nav .sub-menu a{display:block;color:var(--text-body);padding:9px 12px;border-radius:var(--radius-sm);border:none;font-weight:var(--fw-semibold)}
.bn-nav .sub-menu a:hover{background:var(--cream-100);color:var(--accent)}

/* ---- layout grid ---- */
.bn-layout{display:grid;grid-template-columns:minmax(0,1fr) var(--sidebar-w);gap:var(--space-7);padding-top:var(--space-8);padding-bottom:var(--space-9);align-items:start}
.bn-layout__main{min-width:0}

/* ---- bands ---- */
.bn-band{padding:var(--space-8) 0}
.bn-band--feature{background:radial-gradient(120% 90% at 50% -10%,var(--rose-50),transparent 60%),var(--color-bg);border-bottom:1px solid var(--divider)}
.bn-band--archive{background:linear-gradient(180deg,var(--cream-100),var(--color-bg));border-bottom:1px solid var(--divider)}
.bn-section-h{text-align:center;margin-bottom:var(--space-6)}
.bn-section-h h2,.bn-section-h h1{font-size:var(--text-2xl);margin:0}
.bn-section-h__rule{width:48px;height:3px;background:var(--gold-300);border-radius:2px;margin:.5em auto 0}
.bn-section-h--left{text-align:left}
.bn-section-h--left .bn-section-h__rule{margin-inline:0}

/* ---- novel cover (typographic, used when no thumbnail) ---- */
.bn-cover{position:relative;overflow:hidden;border-radius:var(--radius-md);display:flex;flex-direction:column;justify-content:flex-end;aspect-ratio:4/5;color:#fff;text-align:center;box-shadow:var(--shadow-sm);background:linear-gradient(155deg,var(--maroon-700),var(--maroon-900))}
.bn-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bn-cover__scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(42,15,30,.88) 8%,rgba(42,15,30,.3) 55%,rgba(42,15,30,.1) 100%)}
.bn-cover__in{position:relative;padding:var(--space-4)}
.bn-cover__t{font-family:var(--font-display);font-weight:var(--fw-bold);font-size:1.25rem;line-height:1.1;margin:0;text-shadow:0 1px 12px rgba(42,15,30,.5)}
.bn-cover--square{aspect-ratio:1/1}
.bn-cover--img{display:block}
.bn-cover--img img{position:static;width:100%;height:100%;object-fit:cover}
.bn-post__meta a{color:var(--accent);font-weight:var(--fw-bold)}
.bn-post__meta a:hover{color:var(--accent-hover);text-decoration:underline}
.bn-post__meta-static{color:var(--text-muted)}

/* ---- novel card (post list) ---- */
.bn-feed{display:flex;flex-direction:column;gap:var(--space-5)}
.bn-card{display:flex;gap:var(--space-5);background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--dur),transform var(--dur),border-color var(--dur)}
.bn-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--rose-300)}
.bn-card__media{flex:none;width:150px}
.bn-card__media .bn-cover,.bn-card__media img{height:100%;aspect-ratio:auto;border-radius:0;object-fit:cover}
.bn-card__body{flex:1;min-width:0;padding:var(--space-5) var(--space-5) var(--space-5) 0;display:flex;flex-direction:column;gap:var(--space-2)}
.bn-card__cats{display:flex;flex-wrap:wrap;gap:6px}
.bn-card__title{font-size:var(--text-lg);line-height:var(--lh-snug);margin:0}
.bn-card__title a{color:var(--text-strong)}
.bn-card__title a:hover{color:var(--accent)}
.bn-card__meta{display:flex;flex-wrap:wrap;gap:.4em var(--space-4);font-size:var(--text-xs);color:var(--text-muted)}
.bn-card__meta b{color:var(--text-body)}
.bn-card__excerpt{font-size:var(--text-sm);color:var(--text-muted);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.bn-card__more{font-weight:var(--fw-bold);font-size:var(--text-sm);color:var(--accent);margin-top:auto;align-self:flex-start}
.bn-card--v{flex-direction:column;gap:0}
.bn-card--v .bn-card__media{width:100%;height:190px}
.bn-card--v .bn-card__body{padding:var(--space-5)}

/* ---- grids ---- */
.bn-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}
.bn-feature-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-top:var(--space-7)}
.bn-feature-strip__t{font-family:var(--font-display);font-weight:var(--fw-bold);font-size:var(--text-base);margin:8px 0 0;color:var(--text-strong)}

/* ---- pagination ---- */
.bn-pag{display:flex;justify-content:center;gap:6px;margin-top:var(--space-7);flex-wrap:wrap}
.bn-pag .page-numbers{min-width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;padding:0 .6em;border:1px solid var(--border);background:#fff;color:var(--text-body);border-radius:var(--radius-md);font-weight:var(--fw-bold);font-size:var(--text-sm)}
.bn-pag .page-numbers:hover{border-color:var(--brand);color:var(--brand)}
.bn-pag .page-numbers.current{background:var(--brand);border-color:var(--brand);color:#fff}

/* ---- breadcrumb ---- */
.bn-crumbs{display:flex;flex-wrap:wrap;gap:.5em;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-4)}
.bn-crumbs a{color:var(--text-muted)}
.bn-crumbs a:hover{color:var(--accent)}
.bn-crumbs .sep{color:var(--ink-300)}
.bn-crumbs .cur{color:var(--text-strong);font-weight:var(--fw-semibold)}

/* ---- single post ---- */
.bn-post__cats{display:flex;gap:8px;margin-bottom:var(--space-3)}
.bn-post__title{font-size:var(--text-3xl);margin:0 0 var(--space-3);line-height:1.08}
.bn-post__meta{display:flex;flex-wrap:wrap;gap:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--divider);margin-bottom:var(--space-6);font-size:var(--text-sm);color:var(--text-muted)}
.bn-post__meta span{display:inline-flex;align-items:center;gap:7px}
.bn-post__meta svg{width:16px;height:16px;color:var(--accent)}
.bn-post__hero{display:grid;grid-template-columns:300px 1fr;gap:var(--space-6);margin-bottom:var(--space-7);align-items:start}
.bn-post__cover{width:300px;max-width:100%}
.bn-post__cover .bn-cover{aspect-ratio:1/1}
.bn-facts{display:flex;flex-direction:column;gap:var(--space-4)}

/* info table */
.bn-itable{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}
.bn-itable tr:nth-child(odd){background:var(--cream-100)}
.bn-itable th,.bn-itable td{text-align:left;padding:.7em 1em;font-size:var(--text-sm)}
.bn-itable th{width:42%;color:var(--text-muted);font-weight:var(--fw-bold);border-right:1px solid var(--border);white-space:nowrap}
.bn-itable td{color:var(--text-strong);font-weight:var(--fw-semibold)}
.bn-itable .avail{color:var(--success);display:inline-flex;align-items:center;gap:.4em}
.bn-itable .avail::before{content:"";width:.5em;height:.5em;border-radius:50%;background:currentColor}

/* download box */
.bn-download{display:flex;flex-direction:column;gap:var(--space-3);background:var(--cream-100);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5)}
.bn-download__meta{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--text-muted)}
.bn-download__meta b{color:var(--text-strong)}
.bn-download__btns{display:flex;gap:var(--space-3);flex-wrap:wrap}
.bn-download__btns>*{flex:1;min-width:150px}
.bn-download__note{font-size:var(--text-xs);color:var(--text-faint);margin:0}

/* summary content (the_content) */
.bn-content{font-size:var(--text-md);line-height:var(--lh-relaxed);color:var(--text-body)}
.bn-content h2{font-size:var(--text-xl);margin:1.6em 0 .5em;padding-left:var(--space-4);border-left:4px solid var(--accent)}
.bn-content h3{font-size:var(--text-lg);margin:1.4em 0 .4em}
.bn-content ul{padding-left:1.2em}
.bn-content li{margin:.3em 0}
.bn-content img{border-radius:var(--radius-md);margin:1em 0}
.bn-content a{text-decoration:underline}

/* related (silo) */
.bn-related{margin:var(--space-8) 0}
.bn-author-box{display:flex;gap:var(--space-4);align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);margin:var(--space-7) 0}
.bn-author-box__av{width:72px;height:72px;border-radius:50%;flex:none;background:var(--brand-soft);color:var(--brand);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:var(--fw-bold);font-size:26px;overflow:hidden}
.bn-author-box__av img{width:100%;height:100%;object-fit:cover}
.bn-author-box__role{font-size:var(--text-xs);font-weight:var(--fw-bold);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0}
.bn-author-box__name{font-family:var(--font-display);font-size:var(--text-md);margin:2px 0 6px}
.bn-author-box p{margin:0;font-size:var(--text-sm);color:var(--text-muted)}

/* comments */
.bn-comments{margin-top:var(--space-8)}
.bn-comments input[type=text],.bn-comments input[type=email],.bn-comments input[type=url],.bn-comments textarea{width:100%;border:1.5px solid var(--border-strong);border-radius:var(--radius-md);padding:.7em .9em;font-family:inherit;font-size:var(--text-base);margin-bottom:var(--space-4);background:#fff}
.bn-comments textarea:focus,.bn-comments input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}

/* ---- sidebar ---- */
.bn-sb{display:flex;flex-direction:column;gap:var(--space-6);position:sticky;top:180px}
.bn-sb .widget{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5)}
.bn-sb .widget-title,.bn-sb__title{font-family:var(--font-display);font-size:var(--text-md);margin:0 0 var(--space-4);padding-bottom:var(--space-3);border-bottom:2px solid var(--divider);position:relative}
.bn-sb .widget-title::after,.bn-sb__title::after{content:"";position:absolute;bottom:-2px;left:0;width:46px;height:2px;background:var(--accent)}
.bn-sb ul{list-style:none;margin:0;padding:0}
.bn-sb li{border-bottom:1px solid var(--divider)}
.bn-sb li:last-child{border-bottom:none}
.bn-sb li a{display:flex;justify-content:space-between;align-items:center;padding:11px 0;color:var(--text-body);font-size:var(--text-sm);font-weight:var(--fw-semibold)}
.bn-sb li a:hover{color:var(--accent)}
.bn-sb .count{font-family:var(--font-mono);font-size:var(--text-xs);background:var(--cream-100);color:var(--text-muted);padding:2px 9px;border-radius:var(--radius-pill)}
.bn-sb__author{text-align:center}
.bn-sb__author .bn-author-box{flex-direction:column;align-items:center;text-align:center;border:none;box-shadow:none;padding:0;margin:0}
.bn-tagcloud{display:flex;flex-wrap:wrap;gap:8px}
.bn-tagcloud a{padding:.5em .85em;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--text-body)}
.bn-tagcloud a:hover{background:var(--accent-soft);border-color:var(--rose-300);color:var(--rose-700)}

/* ---- footer ---- */
.bn-footer{background:var(--maroon-900);color:var(--rose-100);margin-top:var(--space-9)}
.bn-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-7);padding:var(--space-9) 0 var(--space-8)}
.bn-footer p{color:var(--rose-100);opacity:.78;font-size:var(--text-sm);margin:var(--space-4) 0}
.bn-footer h4{color:#fff;font-size:var(--text-md);margin:0 0 var(--space-4)}
.bn-footer ul{list-style:none;margin:0;padding:0}
.bn-footer a{display:block;color:var(--rose-100);opacity:.8;font-size:var(--text-sm);padding:6px 0}
.bn-footer a:hover{opacity:1;color:var(--gold-300)}
.bn-footer__social{display:flex;gap:10px}
.bn-footer__social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;padding:0}
.bn-footer__social a:hover{background:var(--accent)}
.bn-footer__social svg{width:17px;height:17px}
.bn-footer__bar{border-top:1px solid rgba(255,255,255,.12);font-size:var(--text-xs);opacity:.7}
.bn-footer__bar-in{display:flex;justify-content:space-between;padding:var(--space-4) 0}

/* ---- contact / page ---- */
.bn-page{padding:var(--space-8) 0 var(--space-9)}
.bn-page .bn-content{max-width:760px}
.bn-contact{display:grid;grid-template-columns:1fr 1.1fr;gap:var(--space-8);align-items:start}
.bn-card-pad{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md)}

/* ---- category cards (with image) ---- */
.bn-cat-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out),border-color var(--dur)}
.bn-cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--rose-300)}
.bn-cat-card__media{position:relative;display:block;aspect-ratio:16/9;background:linear-gradient(150deg,var(--maroon-700),var(--maroon-900))}
.bn-cat-card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bn-cat-card__count{position:absolute;left:12px;bottom:12px;z-index:1;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--fw-bold);color:#fff;background:rgba(42,15,30,.7);backdrop-filter:blur(4px);padding:4px 10px;border-radius:var(--radius-pill)}
.bn-cat-card__body{padding:var(--space-5);display:flex;flex-direction:column;gap:4px}
.bn-cat-card__title{font-family:var(--font-display);font-weight:var(--fw-bold);font-size:var(--text-lg);color:var(--text-strong)}
.bn-cat-card:hover .bn-cat-card__title{color:var(--accent)}
.bn-cat-card__sub{font-size:var(--text-sm);color:var(--text-muted)}

/* ---- writers hub grid + cards ---- */
.bn-writer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5)}
.bn-writer-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-4);text-decoration:none;transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out),border-color var(--dur)}
.bn-writer-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--rose-300)}
.bn-writer-card__av{width:92px;height:92px;border-radius:50%;overflow:hidden;background:var(--brand-soft);color:var(--brand);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:var(--fw-bold);font-size:34px;border:3px solid var(--cream-100);box-shadow:var(--shadow-sm)}
.bn-writer-card__av img{width:100%;height:100%;object-fit:cover}
.bn-writer-card__name{font-family:var(--font-display);font-weight:var(--fw-bold);font-size:var(--text-md);color:var(--text-strong);line-height:1.2}
.bn-writer-card:hover .bn-writer-card__name{color:var(--accent)}
.bn-writer-card__count{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);background:var(--cream-100);padding:2px 10px;border-radius:var(--radius-pill)}

/* ---- writer profile hero ---- */
.bn-writer-hero{background:linear-gradient(185deg,var(--maroon-800),var(--maroon-900));color:var(--rose-100)}
.bn-writer-hero .bn-crumbs,.bn-writer-hero .bn-crumbs a{color:var(--rose-300)}
.bn-writer-hero .bn-crumbs .cur{color:#fff}
.bn-writer-head{display:flex;align-items:center;gap:var(--space-6)}
.bn-writer-head__av{width:128px;height:128px;flex:none;border-radius:50%;overflow:hidden;background:var(--cream-50);color:var(--maroon-900);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:var(--fw-bold);font-size:52px;border:4px solid rgba(255,255,255,.18);box-shadow:var(--shadow-md)}
.bn-writer-head__av img{width:100%;height:100%;object-fit:cover}
.bn-writer-head__info h1{color:#fff;margin:.2rem 0 0;font-size:var(--text-3xl)}
.bn-writer-head__meta{color:var(--gold-300);font-weight:var(--fw-semibold);font-size:var(--text-sm);margin:.4rem 0 0}
.bn-writer-head__bio{color:var(--rose-100);opacity:.9;font-size:var(--text-sm);max-width:60ch;margin:.6rem 0 0;line-height:var(--lh-relaxed)}
@media(max-width:760px){.bn-writer-grid{grid-template-columns:repeat(2,1fr)}.bn-writer-head{flex-direction:column;text-align:center}.bn-writer-head__bio{margin-inline:auto}}

/* search results meta */
.bn-search-meta{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-5);font-weight:var(--fw-semibold)}

/* ---- 404 ---- */
.bn-404{max-width:680px;margin:var(--space-7) auto;text-align:center}
.bn-404__title{font-size:var(--text-3xl);margin:.2em 0 .3em}
.bn-404__text{color:var(--text-muted);font-size:var(--text-md);margin:0 auto var(--space-6);max-width:48ch}
.bn-404__search{display:flex;gap:10px;max-width:460px;margin:0 auto var(--space-5)}
.bn-404__search input{flex:1;min-width:0;border:1.5px solid var(--border-strong);border-radius:var(--radius-md);padding:.7em .9em;font-family:inherit;font-size:var(--text-base);background:#fff}
.bn-404__search input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.bn-404__links{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:var(--space-6)}
.bn-404__cats{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.bn-404__cats a{padding:.5em .85em;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--text-body)}
.bn-404__cats a:hover{background:var(--accent-soft);border-color:var(--rose-300);color:var(--rose-700)}
@media(max-width:560px){.bn-404__search{flex-direction:column}.bn-404__title{font-size:var(--text-2xl)}}

/* inline SVG icons */
.kutabnagri .bn-ic{display:inline-block;vertical-align:-.15em;flex:none}
.bn-btn .bn-ic{vertical-align:middle}

/* hamburger (mobile only) */
.bn-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;flex:none;border:1.5px solid var(--border-strong);border-radius:var(--radius-md);background:#fff;cursor:pointer;padding:0 11px}
.bn-burger span{display:block;height:2.5px;border-radius:2px;background:var(--brand);transition:transform var(--dur) var(--ease-out),opacity var(--dur)}
.bn-nav-toggle:checked ~ .bn-header__main .bn-burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.bn-nav-toggle:checked ~ .bn-header__main .bn-burger span:nth-child(2){opacity:0}
.bn-nav-toggle:checked ~ .bn-header__main .bn-burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:980px){
  .bn-layout,.bn-contact{grid-template-columns:1fr}
  .bn-post__hero{grid-template-columns:1fr;justify-items:center;text-align:center}
  .bn-post__cover{width:min(360px,80vw)}
  .bn-facts{width:100%}
  .bn-card{flex-direction:column;gap:0}
  .bn-card__media{width:100%;height:220px}
  .bn-card__body{padding:var(--space-5)}
  .bn-feature-strip{grid-template-columns:repeat(2,1fr)}
  .bn-grid-3{grid-template-columns:repeat(2,1fr)}
  .bn-footer__grid{grid-template-columns:1fr 1fr;gap:var(--space-6)}
}

/* ---- tablet & phone nav / header ---- */
@media(max-width:860px){
  .bn-header__main{flex-wrap:wrap;gap:var(--space-3) var(--space-4);padding:var(--space-3) var(--space-4)}
  .bn-logo__tag{display:none}
  .bn-burger{display:flex}
  .bn-header__search{order:3;width:100%;display:flex}
  /* collapsible nav */
  .bn-nav .bn-wrap{padding:0}
  .bn-nav__list{flex-direction:column;display:none}
  .bn-nav-toggle:checked ~ .bn-nav .bn-nav__list{display:flex}
  .bn-nav__list>li{width:100%;border-bottom:1px solid rgba(255,255,255,.12)}
  .bn-nav__list>li:last-child{border-bottom:none}
  .bn-nav__list a{padding:14px 20px;border-bottom:none;width:100%}
  .bn-nav__list .current-menu-item>a,.bn-nav__list .current_page_item>a{border-bottom:none;border-left:4px solid var(--gold-300)}
  /* submenus inline (no hover on touch) */
  .bn-nav .sub-menu{position:static;display:block;box-shadow:none;border-radius:0;background:rgba(0,0,0,.16);padding:0}
  .bn-nav .sub-menu a{color:var(--rose-100);padding-left:38px}
  .bn-nav .sub-menu a:hover{background:rgba(255,255,255,.08);color:#fff}
  .bn-topbar__inner{font-size:11px}
}

/* ---- small phones ---- */
@media(max-width:560px){
  .bn-wrap{padding-inline:var(--space-4)}
  .bn-post__title{font-size:var(--text-2xl)}
  .bn-section-h h1,.bn-section-h h2{font-size:var(--text-xl)}
  .bn-feature-strip,.bn-grid-3,.bn-writer-grid{grid-template-columns:1fr 1fr}
  .bn-footer__grid{grid-template-columns:1fr;gap:var(--space-5);padding:var(--space-7) 0 var(--space-6)}
  .bn-download__btns{flex-direction:column}
  .bn-download__btns>*{width:100%}
  .bn-post__meta{gap:.4em var(--space-4);font-size:var(--text-xs)}
  .bn-itable th,.bn-itable td{padding:.6em .8em;font-size:var(--text-xs)}
  .bn-topbar__inner span:first-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}
  .bn-writer-head__av{width:96px;height:96px;font-size:38px}
  .bn-writer-head__info h1{font-size:var(--text-2xl)}
  .bn-author-box{flex-direction:column;text-align:center;align-items:center}
}

/* ---- very small phones ---- */
@media(max-width:380px){
  .bn-feature-strip,.bn-grid-3,.bn-writer-grid{grid-template-columns:1fr}
  .bn-card__media{height:200px}
}
