/* ================================================================
   Zenian Theme — septianbw.com
   Professional light theme for Ghost CMS
   ================================================================ */

/* ---- Variables ---- */
:root {
    --zn-primary: #2563eb;
    --zn-primary-hover: #1d4ed8;
    --zn-accent: #60a5fa;
    --zn-gradient: linear-gradient(135deg, #2563eb 0%, #60a5fa 100%);
    --zn-gradient-hover: linear-gradient(135deg, #1d4ed8 0%, #3b82f6 100%);
    --zn-dark: #111827;
    --zn-body: #374151;
    --zn-muted: #6b7280;
    --zn-border: #e5e7eb;
    --zn-bg: #ffffff;
    --zn-bg-alt: #f9fafb;
    --zn-tag-bg: #eff6ff;
    --zn-tag-text: #1d4ed8;

    --gh-font-heading: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --gh-font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --ghost-accent-color: var(--zn-primary);
    --zn-font: var(--gh-font-body);
    --zn-mono: 'Fira Code', 'Cascadia Code', monospace;

    --zn-radius: 0.5rem;
    --zn-radius-lg: 0.875rem;
    --zn-shadow: 0 4px 12px rgba(0,0,0,.07);
    --zn-shadow-lg: 0 10px 40px rgba(0,0,0,.10);
    --zn-transition: 0.18s ease;

    --zn-wide: 1120px;
    --zn-content: 720px;
    --zn-pad: clamp(1.25rem, 5vw, 2.5rem);
}

/* ---- Reset ---- */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body { font-family: var(--zn-font); font-size: 1rem; line-height: 1.75; color: var(--zn-body); background: var(--zn-bg); }
img, video { max-width: 100%; height: auto; display: block; }
a { color: var(--zn-primary); text-decoration: none; transition: color var(--zn-transition); }
a:hover { color: var(--zn-primary-hover); }

/* ---- Layout ---- */
.zn-container { width: 100%; max-width: var(--zn-wide); margin: 0 auto; padding: 0 var(--zn-pad); }
.zn-canvas { max-width: var(--zn-content); margin: 0 auto; padding: 0 var(--zn-pad); }
.zn-outer { padding: 0 var(--zn-pad); }
.zn-site { display: flex; flex-direction: column; min-height: 100vh; }
.zn-main { flex: 1; }

/* ---- Buttons ---- */
.zn-btn {
    display: inline-flex; align-items: center; gap: .5rem;
    font-size: .875rem; font-weight: 600; font-family: var(--zn-font);
    padding: .5625rem 1.25rem; border-radius: var(--zn-radius);
    cursor: pointer; transition: all var(--zn-transition);
    text-decoration: none; border: 1.5px solid transparent; line-height: 1.4;
}
.zn-btn-primary { background: var(--zn-gradient); color: #fff; border-color: transparent; box-shadow: 0 2px 10px rgba(37,99,235,.28); }
.zn-btn-primary:hover { background: var(--zn-gradient-hover); color: #fff; box-shadow: 0 4px 18px rgba(37,99,235,.38); transform: translateY(-1px); }
.zn-btn-outline { background: transparent; color: var(--zn-primary); border-color: var(--zn-primary); }
.zn-btn-outline:hover { background: var(--zn-gradient); color: #fff; border-color: transparent; transform: translateY(-1px); }
.zn-btn-ghost { background: transparent; color: var(--zn-dark); border-color: var(--zn-border); }
.zn-btn-ghost:hover { background: var(--zn-bg-alt); color: var(--zn-dark); border-color: var(--zn-border); }
.zn-btn-lg { padding: .8125rem 1.75rem; font-size: .9375rem; }

/* ---- Tag Pill ---- */
.zn-tag-pill {
    display: inline-block; font-size: .75rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: .04em;
    color: var(--zn-tag-text); background: var(--zn-tag-bg);
    padding: .2rem .65rem; border-radius: 9999px;
    transition: background var(--zn-transition);
}
.zn-tag-pill:hover { background: #dbeafe; color: var(--zn-primary-hover); }

/* ================================================================
   HEADER
   ================================================================ */
.zn-head {
    position: sticky; top: 0; z-index: 100;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--zn-border);
}
.zn-head-inner { height: 64px; display: flex; align-items: center; gap: 1rem; }

.zn-head-logo { display: flex; align-items: center; font-size: 1.25rem; font-weight: 800; color: var(--zn-dark); letter-spacing: -.025em; flex-shrink: 0; }
.zn-head-logo:hover { color: var(--zn-primary); }
.zn-head-logo img { height: 38px; width: auto; }

.zn-head-nav { display: flex; align-items: center; gap: .25rem; flex: 1; justify-content: center; }
.zn-head-nav .nav { display: flex; align-items: center; gap: .25rem; list-style: none; }
.zn-head-nav a { font-size: .9rem; font-weight: 500; color: var(--zn-muted); padding: .375rem .75rem; border-radius: var(--zn-radius); transition: color var(--zn-transition), background var(--zn-transition); display: block; }
.zn-head-nav a:hover, .zn-head-nav a[aria-current="page"] { color: var(--zn-dark); background: var(--zn-bg-alt); }

.zn-head-actions { display: flex; align-items: center; gap: .75rem; flex-shrink: 0; }
.zn-search-btn { background: none; border: none; cursor: pointer; color: var(--zn-muted); padding: .375rem; border-radius: var(--zn-radius); display: flex; align-items: center; transition: color var(--zn-transition), background var(--zn-transition); }
.zn-search-btn:hover { color: var(--zn-dark); background: var(--zn-bg-alt); }

.zn-burger {
    display: none; background: none; border: none; cursor: pointer;
    flex-direction: column; gap: 5px; padding: .375rem;
}
.zn-burger span { display: block; width: 22px; height: 2px; background: var(--zn-dark); border-radius: 2px; transition: all var(--zn-transition); }
.zn-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.zn-burger.is-open span:nth-child(2) { opacity: 0; }
.zn-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Dropdown nav */
.zn-head-nav li[class*="nav-"] { position: relative; }
.zn-head-nav li[class*="nav-"].has-dropdown > a {
    display: flex; align-items: center; gap: .3rem;
}
.zn-head-nav li[class*="nav-"].has-dropdown > a::after {
    content: '';
    display: inline-block;
    width: 0; height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid currentColor;
    opacity: .5;
    transition: transform var(--zn-transition);
    flex-shrink: 0;
}
.zn-head-nav li[class*="nav-"].has-dropdown:hover > a::after,
.zn-head-nav li[class*="nav-"].is-dropdown-open > a::after { opacity: 1; transform: rotate(180deg); }
.zn-head-nav li[class*="nav-"] > ul {
    display: none; position: absolute; top: calc(100% + .375rem); left: 0;
    background: var(--zn-bg);
    border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg);
    box-shadow: 0 8px 32px rgba(0,0,0,.1); padding: .5rem; min-width: 220px;
    list-style: none; z-index: 200;
    animation: dropdown-in .15s ease;
}
@keyframes dropdown-in { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }
.zn-head-nav li[class*="nav-"]:hover > ul,
.zn-head-nav li[class*="nav-"].is-dropdown-open > ul { display: block; }
.zn-head-nav li[class*="nav-"] > ul li a {
    border-radius: var(--zn-radius); display: block;
    padding: .5rem .875rem; font-size: .875rem; color: var(--zn-body);
    white-space: nowrap;
}
.zn-head-nav li[class*="nav-"] > ul li a:hover { background: var(--zn-bg-alt); color: var(--zn-dark); }

/* ================================================================
   HERO (Homepage) — Premium split layout
   ================================================================ */
.zn-hero {
    background: linear-gradient(135deg, #f0f4ff 0%, #f0f9ff 50%, #fafbff 100%);
    padding: 4.5rem 0 4rem;
    border-bottom: 1px solid var(--zn-border);
    overflow: hidden;
    position: relative;
}
.zn-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 80% 20%, rgba(26,86,219,.06) 0%, transparent 60%),
                      radial-gradient(circle at 20% 80%, rgba(14,165,233,.04) 0%, transparent 50%);
    pointer-events: none;
}
.zn-hero-inner {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: 3.5rem;
    align-items: center;
    position: relative;
}

/* Hero Left */
.zn-hero-badge {
    display: inline-flex; align-items: center; gap: .5rem;
    background: #fff; color: var(--zn-primary);
    font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
    padding: .3125rem .875rem; border-radius: 9999px;
    border: 1.5px solid #bfdbfe; margin-bottom: 1.375rem;
    box-shadow: 0 2px 8px rgba(26,86,219,.08);
}
.zn-hero-badge-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 0 2px rgba(34,197,94,.25);
    animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot {
    0%,100% { box-shadow: 0 0 0 2px rgba(34,197,94,.25); }
    50% { box-shadow: 0 0 0 5px rgba(34,197,94,.1); }
}

.zn-hero-title {
    font-size: clamp(1.875rem, 3.5vw, 2.875rem);
    font-weight: 800; color: var(--zn-dark); line-height: 1.18;
    letter-spacing: -.035em; margin-bottom: 1rem;
}
.zn-hero-accent {
    background: linear-gradient(135deg, #2563eb 0%, #38bdf8 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.zn-hero-desc {
    font-size: 1.0625rem; color: var(--zn-muted);
    max-width: 480px; line-height: 1.75; margin-bottom: 1.875rem;
}

.zn-hero-stats {
    display: flex; align-items: center; gap: 0;
    margin-bottom: 2rem; background: #fff;
    border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg);
    padding: .875rem 1.25rem; width: fit-content;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
}
.zn-hero-stat { text-align: center; padding: 0 1rem; }
.zn-hero-stat strong { display: block; font-size: 1.5rem; font-weight: 800; color: var(--zn-dark); letter-spacing: -.03em; line-height: 1.1; }
.zn-hero-stat span { display: block; font-size: .72rem; color: var(--zn-muted); margin-top: .2rem; white-space: nowrap; }
.zn-hero-stat-divider { width: 1px; height: 32px; background: var(--zn-border); flex-shrink: 0; }

.zn-hero-actions {
    display: flex; gap: .75rem; flex-wrap: nowrap; margin-bottom: 1.875rem;
}

.zn-hero-trust { display: flex; align-items: center; gap: .75rem; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.zn-hero-trust::-webkit-scrollbar { display: none; }
.zn-hero-trust-label { font-size: .75rem; font-weight: 600; color: var(--zn-muted); white-space: nowrap; flex-shrink: 0; }
.zn-hero-tags { display: flex; gap: .375rem; flex-wrap: nowrap; }
.zn-hero-tag {
    font-size: .7rem; font-weight: 600; color: var(--zn-body);
    background: #fff; border: 1px solid var(--zn-border);
    padding: .175rem .55rem; border-radius: 9999px;
    transition: all var(--zn-transition); white-space: nowrap; flex-shrink: 0;
}
.zn-hero-tag:hover { border-color: var(--zn-primary); color: var(--zn-primary); background: var(--zn-tag-bg); }

/* Hero Right — Featured Article Card + surrounding badges */
.zn-hero-right { position: relative; padding: 2.75rem 1.75rem 2.75rem 1.75rem; }
.zn-hero-card {
    display: block; background: #fff; border-radius: 1.125rem;
    border: 1px solid var(--zn-border); overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,.12), 0 4px 16px rgba(0,0,0,.06);
    transition: box-shadow var(--zn-transition), transform var(--zn-transition);
    text-decoration: none;
}
.zn-hero-card:hover { box-shadow: 0 24px 70px rgba(0,0,0,.15); transform: translateY(-3px); }
.zn-hero-card-label {
    display: flex; align-items: center; gap: .375rem;
    font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
    color: var(--zn-primary); background: var(--zn-tag-bg);
    padding: .5rem 1rem; border-bottom: 1px solid #bfdbfe;
}
.zn-hero-card-img { aspect-ratio: 16/9; overflow: hidden; background: var(--zn-bg-alt); }
.zn-hero-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.zn-hero-card:hover .zn-hero-card-img img { transform: scale(1.04); }
.zn-hero-card-body { padding: 1.25rem 1.375rem 1.5rem; }
.zn-hero-card-title { font-size: 1.0625rem; font-weight: 700; color: var(--zn-dark); line-height: 1.4; letter-spacing: -.015em; margin: .5rem 0 .625rem; }
.zn-hero-card-meta { font-size: .78rem; color: var(--zn-muted); display: flex; align-items: center; gap: .375rem; }

/* Floating badges — positioned at 4 corners surrounding the card */
.zn-hbf {
    position: absolute; z-index: 3;
    display: flex; align-items: center; gap: .45rem;
    background: #fff; border: 1px solid var(--zn-border);
    border-radius: var(--zn-radius-lg); padding: .45rem .75rem;
    box-shadow: 0 6px 24px rgba(0,0,0,.1);
    animation: float-idle 3.5s ease-in-out infinite;
    white-space: nowrap;
}
.zn-hbf strong { display: block; font-size: .78rem; font-weight: 700; color: var(--zn-dark); line-height: 1.2; }
.zn-hbf span { display: block; font-size: .63rem; color: var(--zn-muted); }
.zn-hbf-tl { top: 4px; left: 4px; animation-delay: 0s; }
.zn-hbf-tr { top: 4px; right: 4px; animation-delay: 1s; }
.zn-hbf-bl { bottom: 4px; left: 4px; animation-delay: 1.8s; }
.zn-hbf-br { bottom: 4px; right: 4px; animation-delay: 2.6s; }

@keyframes float-idle { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }

/* ================================================================
   FEATURED POSTS SECTION
   ================================================================ */
.zn-featured-section {
    background: var(--zn-bg-alt);
    border-bottom: 1px solid var(--zn-border);
    padding: 2rem 0;
}
.zn-featured-header {
    display: flex; align-items: center; margin-bottom: 1.25rem;
}
.zn-featured-label {
    display: inline-flex; align-items: center; gap: .375rem;
    font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
    color: var(--zn-primary); background: var(--zn-tag-bg);
    padding: .3rem .75rem; border-radius: 9999px;
    border: 1px solid #bfdbfe;
}
.zn-featured-label svg { color: #f59e0b; }
.zn-featured-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.125rem;
}
.zn-featured-card {
    display: flex; flex-direction: column;
    background: #fff; border: 1px solid var(--zn-border);
    border-radius: var(--zn-radius-lg); overflow: hidden;
    transition: box-shadow var(--zn-transition), transform var(--zn-transition);
    text-decoration: none;
}
.zn-featured-card:hover { box-shadow: var(--zn-shadow-lg); transform: translateY(-2px); }
.zn-featured-card-img { aspect-ratio: 16/9; overflow: hidden; background: var(--zn-bg-alt); }
.zn-featured-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.zn-featured-card:hover .zn-featured-card-img img { transform: scale(1.04); }
.zn-featured-card-img-placeholder { background: linear-gradient(135deg, #eff6ff, #e0f2fe); }
.zn-featured-card-body { padding: .875rem 1rem 1rem; }
.zn-featured-card-title { font-size: .9375rem; font-weight: 700; color: var(--zn-dark); line-height: 1.4; margin: .375rem 0 .5rem; letter-spacing: -.01em; }
.zn-featured-card-meta { font-size: .75rem; color: var(--zn-muted); display: flex; align-items: center; gap: .375rem; }

/* ================================================================
   FEED SECTION
   ================================================================ */
.zn-feed-section { padding: 3.5rem 0 4rem; }
.zn-feed-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 1.75rem; padding-bottom: .875rem; border-bottom: 2px solid var(--zn-border); }
.zn-feed-title { font-size: 1.375rem; font-weight: 700; color: var(--zn-dark); letter-spacing: -.02em; }
.zn-feed-all { font-size: .875rem; font-weight: 600; color: var(--zn-primary); }
.zn-feed-all:hover { color: var(--zn-primary-hover); }
.zn-feed-layout { display: grid; grid-template-columns: 1fr 300px; gap: 3.5rem; align-items: start; }
.zn-feed { min-width: 0; }

/* ================================================================
   SECTION HEADER (generic)
   ================================================================ */
.zn-section-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 1.75rem; padding-bottom: .875rem; border-bottom: 1px solid var(--zn-border); }
.zn-section-title { font-size: 1.375rem; font-weight: 700; color: var(--zn-dark); letter-spacing: -.02em; }
.zn-section-count { font-size: .875rem; color: var(--zn-muted); }
.zn-section-link { font-size: .875rem; font-weight: 600; color: var(--zn-primary); }
.zn-section-link:hover { color: var(--zn-primary-hover); }

/* ================================================================
   POST GRID
   ================================================================ */
.zn-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }

/* Tag page — 4-column grid, first post large */
.zn-tag-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
.zn-tag-grid .zn-card:first-child { grid-column: 1 / -1; }
.zn-tag-grid .zn-card:first-child .zn-card-img-wrap { aspect-ratio: unset; }
.zn-tag-grid .zn-card:first-child .zn-card-title { font-size: 1.5rem; letter-spacing: -.025em; }

/* ================================================================
   POST CARD — Magazine style
   ================================================================ */
.zn-card {
    background: var(--zn-bg); border: 1px solid var(--zn-border);
    border-radius: var(--zn-radius-lg); overflow: hidden;
    display: flex; flex-direction: column;
    transition: box-shadow var(--zn-transition), transform var(--zn-transition);
}
.zn-card:hover { box-shadow: var(--zn-shadow-lg); transform: translateY(-3px); }

.zn-card-img-wrap { aspect-ratio: 16/9; overflow: hidden; background: var(--zn-bg-alt); display: block; }
.zn-card-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.zn-card:hover .zn-card-img-wrap img { transform: scale(1.04); }
.zn-card-body { padding: 1.125rem 1.25rem 1.25rem; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.zn-card-tag { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--zn-primary); display: inline-block; margin-bottom: .125rem; }
.zn-card-tag:hover { color: var(--zn-primary-hover); }
.zn-card-title { font-size: 1rem; font-weight: 700; color: var(--zn-dark); line-height: 1.4; letter-spacing: -.015em; }
.zn-card-title a { color: inherit; }
.zn-card-title a:hover { color: var(--zn-primary); }
.zn-card-excerpt { font-size: .875rem; color: var(--zn-muted); line-height: 1.65; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.zn-card-footer { display: flex; align-items: center; gap: .5rem; font-size: .78rem; color: var(--zn-muted); margin-top: auto; padding-top: .75rem; border-top: 1px solid var(--zn-border); flex-wrap: wrap; }
.zn-meta-sep { color: var(--zn-border); }

/* ================================================================
   SIDEBAR
   ================================================================ */
.zn-sidebar { display: flex; flex-direction: column; gap: 1.5rem; position: sticky; top: 80px; }
.zn-widget { background: var(--zn-bg); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); padding: 1.25rem; }
.zn-widget-newsletter { background: linear-gradient(135deg, #eff6ff, #f0f9ff); border-color: #bfdbfe; }
.zn-widget-title { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--zn-muted); margin-bottom: .875rem; padding-bottom: .625rem; border-bottom: 1px solid var(--zn-border); }
.zn-widget-newsletter .zn-widget-title { color: var(--zn-primary); border-color: #bfdbfe; }
.zn-widget-desc { font-size: .875rem; color: var(--zn-body); line-height: 1.6; margin-bottom: .75rem; }
.zn-tag-cloud { display: flex; flex-wrap: wrap; gap: .375rem; }
.zn-sidebar-author { display: flex; gap: .75rem; align-items: flex-start; }
.zn-sidebar-author-img { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2px solid var(--zn-border); }
.zn-sidebar-author-name { font-size: .875rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .25rem; }
.zn-sidebar-author-bio { font-size: .8rem; color: var(--zn-muted); line-height: 1.5; margin-bottom: .5rem; }
.zn-sidebar-posts { list-style: none; display: flex; flex-direction: column; gap: .875rem; }
.zn-sidebar-posts li { display: flex; gap: .625rem; align-items: flex-start; }
/* Sidebar author avatar placeholder */
.zn-sidebar-author-avatar {
    width: 52px; height: 52px; border-radius: 50%; flex-shrink: 0;
    background: linear-gradient(135deg, var(--zn-primary), var(--zn-accent));
    color: #fff; font-size: .85rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
}

/* Sidebar post list */
.zn-sidebar-post-thumb-wrap { display: block; flex-shrink: 0; }
.zn-sidebar-post-info { display: flex; flex-direction: column; gap: .2rem; min-width: 0; }
/* Fixed: wider thumbnail, top-anchored, so branded image text isn't cut */
.zn-sidebar-post-thumb { width: 76px; height: 58px; border-radius: .375rem; object-fit: cover; object-position: center top; background: var(--zn-bg-alt); display: block; }
.zn-sidebar-thumb-placeholder { background: linear-gradient(135deg, #eff6ff, #e0f2fe); }
.zn-sidebar-post-title { display: block; font-size: .85rem; font-weight: 600; color: var(--zn-dark); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.zn-sidebar-post-title:hover { color: var(--zn-primary); }
.zn-sidebar-post-date { display: block; font-size: .75rem; color: var(--zn-muted); margin-top: .2rem; }

/* ================================================================
   PAGINATION
   ================================================================ */
.zn-pagination { display: flex; align-items: center; justify-content: center; gap: .625rem; margin-top: 3rem; padding-top: 2rem; padding-bottom: 2rem; border-top: 1px solid var(--zn-border); }
.zn-page-btn { display: inline-flex; align-items: center; padding: .5rem 1.125rem; border-radius: var(--zn-radius); font-size: .875rem; font-weight: 600; color: var(--zn-body); border: 1px solid var(--zn-border); transition: all var(--zn-transition); }
.zn-page-btn:hover { background: var(--zn-bg-alt); color: var(--zn-dark); }
.zn-page-current { font-size: .875rem; color: var(--zn-muted); padding: .5rem .75rem; }

/* ================================================================
   ARTICLE
   ================================================================ */
.zn-article { }
.zn-article-header { padding: 3rem 0 2.5rem; background: var(--zn-bg); }
.zn-article-tag { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--zn-primary); display: inline-block; margin-bottom: .875rem; }
.zn-article-tag:hover { color: var(--zn-primary-hover); }
.zn-article-title { font-size: clamp(1.75rem, 4vw, 2.75rem); font-weight: 800; color: var(--zn-dark); line-height: 1.2; letter-spacing: -.03em; margin-bottom: 1rem; }
.zn-article-excerpt { font-size: 1.125rem; color: var(--zn-muted); line-height: 1.7; margin-bottom: 1.5rem; }

.zn-article-meta { display: flex; align-items: center; gap: .875rem; margin-bottom: 2rem; }
.zn-author-images { display: flex; }
.zn-author-img-link { display: block; width: 40px; height: 40px; border-radius: 50%; overflow: hidden; border: 2px solid var(--zn-bg); margin-right: -8px; }
.zn-author-img-link img { width: 100%; height: 100%; object-fit: cover; }
.zn-author-img-placeholder { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; background: var(--zn-primary); color: #fff; font-weight: 700; font-size: .875rem; }
.zn-author-names { font-size: .9rem; font-weight: 600; color: var(--zn-dark); }
.zn-author-names a { color: inherit; }
.zn-author-names a:hover { color: var(--zn-primary); }
.zn-article-meta-row { font-size: .8rem; color: var(--zn-muted); display: flex; align-items: center; gap: .375rem; flex-wrap: wrap; }

.zn-article-image { margin-top: 2rem; border-radius: var(--zn-radius-lg); overflow: hidden; }
.zn-article-image img { width: 100%; height: auto; display: block; }
.zn-article-image figcaption { font-size: .875rem; color: var(--zn-muted); text-align: center; padding: .625rem 0 0; }

/* Article Body */
.zn-content { padding: 2.5rem 0 3.5rem; font-size: 1.0625rem; line-height: 1.8; }
.zn-content p { margin-bottom: 1.625em; }
.zn-content h2, .zn-content h3, .zn-content h4 { font-weight: 700; color: var(--zn-dark); letter-spacing: -.02em; margin: 2.5em 0 .875em; line-height: 1.3; }
.zn-content h2 { font-size: 1.625rem; }
.zn-content h3 { font-size: 1.3125rem; }
.zn-content h4 { font-size: 1.125rem; }
.zn-content a { color: var(--zn-primary); text-decoration: none; }
.zn-content a:hover { color: var(--zn-primary-hover); }
.zn-content ul, .zn-content ol { padding-left: 1.75em; margin-bottom: 1.5em; }
.zn-content li { margin-bottom: .5em; }
.zn-content blockquote { border-left: 4px solid var(--zn-primary); padding: 1rem 1.25rem; margin: 2em 0; background: var(--zn-tag-bg); border-radius: 0 var(--zn-radius) var(--zn-radius) 0; font-style: italic; color: var(--zn-dark); }
.zn-content blockquote p:last-child { margin-bottom: 0; }
.zn-content code { font-family: var(--zn-mono); font-size: .875em; background: #f3f4f6; border: 1px solid var(--zn-border); padding: .15em .45em; border-radius: .3rem; color: #c7254e; }
.zn-content pre { background: var(--zn-dark); color: #f3f4f6; border-radius: var(--zn-radius-lg); padding: 1.5rem; overflow-x: auto; margin: 2em 0; font-size: .9rem; line-height: 1.7; }
.zn-content pre code { background: none; border: none; padding: 0; color: inherit; font-size: inherit; }
.zn-content img { border-radius: var(--zn-radius-lg); margin: 2em 0; box-shadow: var(--zn-shadow); }
.zn-content figure { margin: 2em 0; }
.zn-content figcaption { font-size: .875rem; color: var(--zn-muted); text-align: center; margin-top: .5rem; }
.zn-content table { width: 100%; border-collapse: collapse; margin: 2em 0; font-size: .9rem; }
.zn-content th, .zn-content td { padding: .75rem 1rem; border: 1px solid var(--zn-border); text-align: left; }
.zn-content th { background: var(--zn-bg-alt); font-weight: 600; color: var(--zn-dark); }
.zn-content tr:nth-child(even) td { background: var(--zn-bg-alt); }
.zn-content hr { border: none; border-top: 1px solid var(--zn-border); margin: 2.5em 0; }

/* Ghost Card Styles */
.zn-content .kg-width-wide { max-width: 1000px; margin-left: auto; margin-right: auto; }
.zn-content .kg-width-full { max-width: none; width: 100vw; margin-left: calc(50% - 50vw); }
.zn-content .kg-image-card img { width: 100%; }
.zn-content .kg-callout-card { border-radius: var(--zn-radius-lg); padding: 1.25rem 1.5rem; margin: 2em 0; display: flex; gap: 1rem; background: var(--zn-bg-alt); border: 1px solid var(--zn-border); }
.zn-content .kg-callout-emoji { font-size: 1.5rem; flex-shrink: 0; }
.zn-content .kg-button-card { text-align: center; margin: 2em 0; }
.zn-content .kg-button-card a { display: inline-flex; background: var(--zn-primary); color: #fff !important; font-weight: 600; padding: .75rem 1.75rem; border-radius: var(--zn-radius); text-decoration: none !important; }
.zn-content .kg-button-card a:hover { background: var(--zn-primary-hover); }

/* Article Footer */
.zn-article-footer { padding: 0 0 3.5rem; }
.zn-article-tags { display: flex; align-items: center; flex-wrap: wrap; gap: .375rem; margin-bottom: 1.5rem; }
.zn-tags-label { font-size: .8rem; font-weight: 600; color: var(--zn-muted); margin-right: .25rem; }

.zn-share { display: flex; align-items: center; gap: .625rem; flex-wrap: wrap; padding: 1.125rem; background: var(--zn-bg-alt); border-radius: var(--zn-radius-lg); border: 1px solid var(--zn-border); margin-bottom: 2rem; }
.zn-share-label { font-size: .8rem; font-weight: 600; color: var(--zn-muted); }
.zn-share-btn { display: inline-flex; align-items: center; gap: .3rem; font-size: .75rem; font-weight: 600; padding: .28rem .7rem; border-radius: var(--zn-radius); transition: all var(--zn-transition); text-decoration: none; cursor: pointer; border: none; font-family: var(--zn-font); }
.zn-share-wa { background: #f0fdf4; color: #25d366; }
.zn-share-wa:hover { background: #25d366; color: #fff; }
.zn-share-fb { background: #eff6ff; color: #1877f2; }
.zn-share-fb:hover { background: #1877f2; color: #fff; }
.zn-share-tg { background: #f0f9ff; color: #229ed9; }
.zn-share-tg:hover { background: #229ed9; color: #fff; }
.zn-share-li { background: #eff6ff; color: #0a66c2; }
.zn-share-li:hover { background: #0a66c2; color: #fff; }
.zn-share-tw { background: #f8fafc; color: #1d9bf0; }
.zn-share-tw:hover { background: #1d9bf0; color: #fff; }
.zn-share-copy { background: #f3f4f6; color: var(--zn-body); }
.zn-share-copy:hover { background: var(--zn-border); }

.zn-author-box { display: flex; gap: 1.125rem; padding: 1.375rem; background: var(--zn-bg-alt); border-radius: var(--zn-radius-lg); border: 1px solid var(--zn-border); margin-bottom: 2rem; }
.zn-author-box-img { width: 68px; height: 68px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 3px solid var(--zn-border); }
.zn-author-box-name { font-size: 1rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .25rem; }
.zn-author-box-bio { font-size: .875rem; color: var(--zn-muted); line-height: 1.6; margin-bottom: .875rem; }
.zn-author-box-footer { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .625rem; }
.zn-author-box-social { display: flex; align-items: center; gap: .625rem; }
.zn-author-box-social a { color: var(--zn-muted); transition: color var(--zn-transition); display: flex; }
.zn-author-box-social a:hover { color: var(--zn-dark); }

/* Related Posts */
.zn-related { padding: 3rem 0; border-top: 1px solid var(--zn-border); }
.zn-related-title { font-size: 1.25rem; font-weight: 700; color: var(--zn-dark); margin-bottom: 1.5rem; }
.zn-related .zn-grid { grid-template-columns: repeat(3, 1fr); }

/* Comments */
.zn-comments { padding: 2.5rem 0 3rem; }

/* TOC — Tocbot */
.zn-toc-wrap {
    margin-bottom: 2.5rem;
    border: 1px solid var(--zn-border);
    border-radius: var(--zn-radius-lg);
    overflow: hidden;
    background: var(--zn-bg-alt);
}
.zn-toc-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: .75rem 1.25rem; cursor: pointer;
    background: var(--zn-bg-alt);
}
.zn-toc-label { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--zn-dark); display: flex; align-items: center; gap: .5rem; }
.zn-toc-toggle { font-size: .75rem; color: var(--zn-muted); }
.zn-toc-body { padding: 1rem 1.25rem; }
.js-toc { }
.toc-list { list-style: none; padding-left: 0; }
.toc-list-item { margin: .3rem 0; }
.toc-list .toc-list { padding-left: 1rem; }
.toc-link { font-size: .85rem; color: var(--zn-muted); text-decoration: none; transition: color var(--zn-transition); display: block; padding: .15rem 0; }
.toc-link:hover, .toc-link.is-active-link { color: var(--zn-primary); }
.is-active-link { font-weight: 600; }

/* ================================================================
   TAG / AUTHOR PAGES
   ================================================================ */
.zn-cover { position: relative; height: 360px; overflow: hidden; background: var(--zn-dark); }
.zn-cover-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .5; }
.zn-cover-content { position: relative; z-index: 1; text-align: center; padding: 4rem var(--zn-pad); }
.zn-cover-title { font-size: clamp(2rem, 5vw, 3rem); font-weight: 800; color: #fff; letter-spacing: -.03em; }
.zn-cover-desc { color: rgba(255,255,255,.8); margin-top: .75rem; font-size: 1.125rem; }

.zn-pagehead { padding: 3rem 0 2.5rem; text-align: center; border-bottom: 1px solid var(--zn-border); margin-bottom: 2.5rem; }
.zn-pagehead-title { font-size: 2rem; font-weight: 800; color: var(--zn-dark); letter-spacing: -.03em; }
.zn-pagehead-desc { color: var(--zn-muted); max-width: 500px; margin: .5rem auto 0; font-size: .95rem; line-height: 1.7; }
.zn-pagehead-count { font-size: .875rem; color: var(--zn-muted); margin-top: .375rem; }

.zn-pagehead-author { display: flex; flex-direction: column; align-items: center; text-align: center; }
.zn-author-profile-img { width: 88px; height: 88px; border-radius: 50%; overflow: hidden; border: 4px solid var(--zn-border); margin-bottom: 1rem; }
.zn-author-profile-img img { width: 100%; height: 100%; object-fit: cover; }
.zn-author-profile-img span { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; background: var(--zn-primary); color: #fff; font-size: 2rem; font-weight: 700; }
.zn-author-location { font-size: .875rem; color: var(--zn-muted); margin: .375rem 0; }
.zn-author-social-links { display: flex; gap: .5rem; justify-content: center; flex-wrap: wrap; margin-top: .875rem; }

/* ================================================================
   JASA PAGE
   ================================================================ */
.zn-jasa-hero { background: linear-gradient(135deg, #eff6ff 0%, #e0f2fe 60%, #f0f9ff 100%); padding: 5rem var(--zn-pad) 4rem; text-align: center; border-bottom: 1px solid var(--zn-border); }
.zn-jasa-hero-title { font-size: clamp(1.75rem, 4.5vw, 2.875rem); font-weight: 800; color: var(--zn-dark); line-height: 1.2; letter-spacing: -.03em; max-width: 680px; margin: .875rem auto 1.125rem; }
.zn-jasa-hero-title span { color: var(--zn-primary); }
.zn-jasa-hero-desc { font-size: 1.125rem; color: var(--zn-muted); max-width: 540px; margin: 0 auto 2rem; line-height: 1.7; }

.zn-stats-bar { background: var(--zn-dark); padding: 2.5rem var(--zn-pad); }
.zn-stats-grid { max-width: var(--zn-content); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; text-align: center; }
.zn-stat-num { display: block; font-size: 2rem; font-weight: 800; color: #fff; letter-spacing: -.025em; }
.zn-stat-label { display: block; font-size: .8rem; color: rgba(255,255,255,.6); margin-top: .25rem; }

.zn-services-section { padding: 5rem var(--zn-pad); }
.zn-services-grid { max-width: var(--zn-content); margin: 0 auto; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.zn-service-card { background: var(--zn-bg); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); padding: 1.75rem; display: flex; flex-direction: column; gap: .875rem; transition: box-shadow var(--zn-transition); }
.zn-service-card:hover { box-shadow: var(--zn-shadow-lg); }
.zn-service-featured { border-color: var(--zn-primary); background: linear-gradient(135deg, #eff6ff, #fff); grid-column: span 2; flex-direction: row; gap: 2.5rem; }
.zn-service-icon { font-size: 2rem; flex-shrink: 0; }
.zn-service-name { font-size: 1.25rem; font-weight: 700; color: var(--zn-dark); }
.zn-service-desc { font-size: .9rem; color: var(--zn-muted); line-height: 1.7; }
.zn-service-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .375rem; flex: 1; }
.zn-service-list li { font-size: .9rem; color: var(--zn-body); padding-left: 1.25rem; position: relative; }
.zn-service-list li::before { content: '✓'; position: absolute; left: 0; color: var(--zn-primary); font-weight: 700; font-size: .8rem; }

.zn-process-section { background: var(--zn-bg-alt); padding: 5rem var(--zn-pad); border-top: 1px solid var(--zn-border); border-bottom: 1px solid var(--zn-border); }
.zn-process-grid { max-width: var(--zn-content); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.zn-process-step { text-align: center; }
.zn-process-num { font-size: 2.25rem; font-weight: 900; color: #dbeafe; letter-spacing: -.05em; margin-bottom: .5rem; }
.zn-process-step h4 { font-size: 1rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .5rem; }
.zn-process-step p { font-size: .875rem; color: var(--zn-muted); line-height: 1.65; }

.zn-cta-section { padding: 5rem var(--zn-pad); }
.zn-cta-box { max-width: var(--zn-content); margin: 0 auto; background: linear-gradient(135deg, var(--zn-primary), #1e429f); border-radius: var(--zn-radius-lg); padding: 3.5rem 2rem; text-align: center; }
.zn-cta-title { font-size: 1.875rem; font-weight: 800; color: #fff; letter-spacing: -.025em; margin-bottom: .875rem; }
.zn-cta-desc { color: rgba(255,255,255,.85); font-size: 1.0625rem; margin-bottom: 2rem; line-height: 1.65; }
.zn-cta-box .zn-btn-primary { background: #fff; color: var(--zn-primary); border-color: #fff; }
.zn-cta-box .zn-btn-primary:hover { background: #eff6ff; }
.zn-cta-box .zn-btn-outline { border-color: rgba(255,255,255,.6); color: #fff; }
.zn-cta-box .zn-btn-outline:hover { background: rgba(255,255,255,.15); color: #fff; }

/* ================================================================
   ABOUT PAGE
   ================================================================ */
.zn-about-hero { background: linear-gradient(135deg, #eff6ff, #f9fafb); padding: 4.5rem var(--zn-pad); border-bottom: 1px solid var(--zn-border); }
.zn-about-hero-inner { max-width: var(--zn-content); margin: 0 auto; display: grid; grid-template-columns: 200px 1fr; gap: 3rem; align-items: center; }
.zn-about-hero-img { width: 200px; height: 200px; border-radius: 50%; overflow: hidden; border: 5px solid var(--zn-border); flex-shrink: 0; box-shadow: var(--zn-shadow-lg); }
.zn-about-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.zn-about-hero-placeholder { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; background: linear-gradient(135deg, var(--zn-primary), var(--zn-accent)); color: #fff; font-size: 3.5rem; font-weight: 800; }
.zn-about-hero-title { font-size: clamp(1.625rem, 3.5vw, 2.25rem); font-weight: 800; color: var(--zn-dark); letter-spacing: -.03em; margin: .75rem 0 .375rem; }
.zn-about-hero-role { font-size: 1rem; font-weight: 600; color: var(--zn-primary); margin-bottom: .875rem; }
.zn-about-hero-desc { font-size: .9625rem; color: var(--zn-muted); line-height: 1.72; margin-bottom: 1.25rem; }
.zn-about-socials { display: flex; gap: .5rem; flex-wrap: wrap; }

.zn-about-section { padding: 4rem var(--zn-pad); }
.zn-about-grid { max-width: var(--zn-wide); margin: 0 auto; display: grid; grid-template-columns: 1fr 280px; gap: 3.5rem; align-items: start; }
.zn-about-heading { font-size: 1.5rem; font-weight: 700; color: var(--zn-dark); letter-spacing: -.02em; margin: 2.5rem 0 1rem; }
.zn-about-main p { font-size: 1.0625rem; color: var(--zn-body); line-height: 1.8; margin-bottom: 1.25em; }

.zn-skills-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.125rem; margin: 2rem 0; }
.zn-skill-item { background: var(--zn-bg-alt); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); padding: 1.125rem; }
.zn-skill-icon { font-size: 1.5rem; margin-bottom: .5rem; }
.zn-skill-item h4 { font-size: .9rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .3rem; }
.zn-skill-item p { font-size: .8rem; color: var(--zn-muted); line-height: 1.55; margin: 0; }

.zn-about-aside { display: flex; flex-direction: column; gap: 1.375rem; position: sticky; top: 80px; }
.zn-about-widget { background: var(--zn-bg); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); padding: 1.25rem; }
.zn-about-widget-title { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--zn-muted); margin-bottom: 1rem; padding-bottom: .625rem; border-bottom: 1px solid var(--zn-border); }
.zn-cta-widget { background: linear-gradient(135deg, #eff6ff, #f0f9ff); border-color: #bfdbfe; }
.zn-about-contact-list { list-style: none; display: flex; flex-direction: column; gap: .75rem; }
.zn-about-contact-list li { display: flex; flex-direction: column; gap: .15rem; font-size: .875rem; }
.zn-about-contact-list span:first-child { font-weight: 600; color: var(--zn-dark); font-size: .8rem; }
.zn-about-contact-list a, .zn-about-contact-list span:last-child { color: var(--zn-muted); font-size: .875rem; }
.zn-tools-list { display: flex; flex-wrap: wrap; gap: .375rem; }

/* About page — social icon buttons */
.zn-about-social-btn {
    display: inline-flex; align-items: center; gap: .4rem;
    font-size: .8rem; font-weight: 600; color: var(--zn-body);
    background: #fff; border: 1px solid var(--zn-border);
    padding: .375rem .875rem; border-radius: 9999px;
    transition: all var(--zn-transition);
}
.zn-about-social-btn:hover { background: var(--zn-primary); border-color: var(--zn-primary); color: #fff; }

/* ================================================================
   FOOTER — Light, premium
   ================================================================ */
.zn-foot {
    background: #f8fafc;
    color: var(--zn-body);
    margin-top: auto;
    border-top: 1px solid var(--zn-border);
}
.zn-foot::before {
    content: '';
    display: block;
    height: 3px;
    background: linear-gradient(90deg, var(--zn-primary) 0%, var(--zn-accent) 100%);
}
.zn-foot-inner { padding: 3rem 0 2rem; }

/* Footer Lead Form */
.zn-foot-lead { margin-bottom: 3rem; }
.zn-foot-lead-inner {
    background: #fff; border: 1px solid var(--zn-border);
    border-radius: var(--zn-radius-lg); padding: 2.5rem 2rem;
    box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
.zn-foot-lead-text { margin-bottom: 1.5rem; }
.zn-foot-lead-title { font-size: 1.25rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .25rem; }
.zn-foot-lead-desc { font-size: .9rem; color: var(--zn-muted); }
.zn-lead-form { display: flex; flex-direction: column; gap: .75rem; }
.zn-lead-row { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.zn-lead-input {
    width: 100%; padding: .625rem .875rem;
    border: 1.5px solid var(--zn-border); border-radius: var(--zn-radius);
    font-size: .875rem; font-family: var(--zn-font); color: var(--zn-body);
    background: var(--zn-bg); transition: border-color var(--zn-transition);
    outline: none;
}
.zn-lead-input:focus { border-color: var(--zn-primary); box-shadow: 0 0 0 3px rgba(26,86,219,.1); }
.zn-lead-textarea { resize: vertical; min-height: 90px; }
.zn-lead-submit { align-self: flex-start; }
.zn-lead-note { font-size: .75rem; color: var(--zn-muted); margin-top: -.25rem; }
.zn-foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.zn-foot-logo { display: flex; align-items: center; gap: .5rem; font-size: 1.125rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .875rem; }
.zn-foot-logo:hover { color: var(--zn-primary); }
.zn-foot-desc { font-size: .875rem; color: var(--zn-muted); line-height: 1.7; margin-bottom: 1.125rem; }
.zn-foot-social { display: flex; gap: .5rem; }
.zn-foot-social a { width: 34px; height: 34px; border-radius: 50%; background: #fff; border: 1px solid var(--zn-border); display: flex; align-items: center; justify-content: center; color: var(--zn-muted); transition: all var(--zn-transition); }
.zn-foot-social a:hover { background: var(--zn-primary); border-color: var(--zn-primary); color: #fff; }
.zn-foot-col-title { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--zn-dark); margin-bottom: 1rem; }
/* Footer nav columns — Ghost outputs <ul class="nav"> directly (no wrapping <nav> tag) */
.zn-foot-links,
.zn-foot-col .nav { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; }
.zn-foot-links a,
.zn-foot-col .nav a { font-size: .875rem; color: var(--zn-muted); transition: color var(--zn-transition); display: block; }
.zn-foot-links a:hover,
.zn-foot-col .nav a:hover { color: var(--zn-dark); }
/* Sub-nav items — items stripped of "-" prefix by JS, indented with left border */
.zn-foot-col .nav .nav-sub a {
    font-size: .82rem; padding-left: .75rem;
    border-left: 2px solid var(--zn-border); color: var(--zn-muted);
}
.zn-foot-col .nav .nav-sub a:hover { color: var(--zn-dark); border-color: var(--zn-primary); }
.zn-foot-bottom { padding-top: 1.5rem; border-top: 1px solid var(--zn-border); display: flex; flex-direction: column; align-items: center; text-align: center; font-size: .75rem; color: var(--zn-muted); gap: .5rem; }
.zn-foot-bottom a { color: var(--zn-muted); }
.zn-foot-bottom a:hover { color: var(--zn-primary); }
.zn-foot-bottom-links { display: flex; align-items: center; justify-content: center; gap: .5rem; flex-wrap: wrap; }

/* ================================================================
   ERROR PAGE
   ================================================================ */
.zn-error-page { min-height: 60vh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 4rem var(--zn-pad); }
.zn-error-code { font-size: clamp(5rem, 15vw, 9rem); font-weight: 900; color: #e5e7eb; line-height: 1; letter-spacing: -.05em; }
.zn-error-title { font-size: 1.625rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .75rem; }
.zn-error-desc { color: var(--zn-muted); margin-bottom: 2rem; max-width: 420px; }

/* ================================================================
   READING PROGRESS
   ================================================================ */
.zn-progress { position: fixed; top: 0; left: 0; width: 0%; height: 3px; background: linear-gradient(90deg, var(--zn-primary), var(--zn-accent)); z-index: 200; transition: width .1s linear; }

/* ================================================================
   SCROLL TO TOP
   ================================================================ */
.scroll-top {
    position: fixed; bottom: 2rem; right: 2rem; z-index: 150;
    width: 44px; height: 44px;
    background: var(--zn-bg); border: 1.5px solid var(--zn-border);
    border-radius: 50%; cursor: pointer; display: none;
    align-items: center; justify-content: center;
    color: var(--zn-primary); padding: 0;
    box-shadow: 0 4px 16px rgba(0,0,0,.1);
    transition: all var(--zn-transition);
}
.scroll-top.is-visible { display: flex; }
.scroll-top:hover { background: var(--zn-primary); color: #fff; border-color: var(--zn-primary); }
.scroll-top .progress-circle { position: absolute; inset: -3px; width: calc(100% + 6px); height: calc(100% + 6px); transform: rotate(-90deg); }
.scroll-top .progress-circle path { fill: none; stroke: var(--zn-primary); stroke-width: 4; stroke-dasharray: 307.92; stroke-dashoffset: 307.92; transition: stroke-dashoffset .1s linear; }
.scroll-top .icon-arrow-up { position: relative; z-index: 1; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 1024px) {
    .zn-hero-inner { grid-template-columns: 1fr; max-width: 680px; }
    .zn-hero-right { display: none; }
    .zn-hero-stats { width: auto; }
    .zn-feed-layout { grid-template-columns: 1fr; }
    .zn-sidebar { display: none; }
    .zn-foot-grid { grid-template-columns: 1fr 1fr; }
    .zn-about-grid { grid-template-columns: 1fr; }
    .zn-about-aside { position: static; }
}

@media (max-width: 768px) {
    :root { --zn-pad: 1.25rem; }
    .zn-featured-grid { grid-template-columns: 1fr; }

    /* Header mobile: burger left, logo center, actions right */
    .zn-head-inner { position: relative; }
    .zn-head-nav { display: none; }
    .zn-head-nav.is-open {
        display: block;
        position: fixed; top: 64px; left: 0; right: 0;
        background: var(--zn-bg); border-bottom: 1px solid var(--zn-border);
        padding: 1rem var(--zn-pad); box-shadow: var(--zn-shadow); z-index: 99;
        overflow-y: auto; max-height: calc(100vh - 64px);
    }
    .zn-head-nav.is-open .nav { display: flex; flex-direction: column; align-items: flex-start; width: 100%; gap: 0; list-style: none; }
    .zn-head-nav.is-open .nav > li { width: 100%; }
    .zn-head-nav.is-open .nav > li > a { display: block; text-align: left; padding: .75rem 0; border-bottom: 1px solid var(--zn-border); font-weight: 600; color: var(--zn-dark); }
    /* Mobile sub-items: flat indented, no floating dropdown */
    .zn-head-nav.is-open .nav > li > ul {
        display: block !important; position: static !important;
        box-shadow: none !important; border: none !important; border-radius: 0 !important;
        padding: 0 0 0 1rem !important; background: transparent !important;
        animation: none !important;
    }
    .zn-head-nav.is-open .nav > li > ul li a {
        padding: .5rem 0; border-bottom: 1px solid var(--zn-border);
        font-size: .875rem; color: var(--zn-muted); border-radius: 0;
    }
    .zn-head-nav.is-open .nav > li.has-dropdown > a::after { display: none; }
    .zn-burger { display: flex; flex-shrink: 0; order: 1; }
    .zn-head-logo { flex: 1; justify-content: center; order: 2; }
    .zn-head-actions { order: 3; }
    .zn-head-subscribe { display: none; }

    .zn-hero { padding: 2.5rem 0 2rem; }
    .zn-hero-right { display: none; }
    .zn-hero-stats { width: fit-content; padding: .625rem .75rem; }
    .zn-hero-stat { padding: 0 .625rem; }
    .zn-hero-stat strong { font-size: 1.2rem; }
    .zn-hero-stat span { font-size: .6rem; }
    .zn-hero-stat-divider { height: 24px; }
    .zn-hero-actions .zn-btn-lg { padding: .6875rem 1rem; font-size: .875rem; }
    .zn-hero-trust { flex-direction: column; align-items: flex-start; overflow-x: visible; }
    .zn-hero-tags { flex-wrap: wrap; overflow-x: visible; }
    .zn-hero-trust-label { font-size: .7rem; flex-shrink: 0; }

    .zn-canvas { padding-left: 1rem; padding-right: 1rem; }
    .zn-outer { padding-left: 1rem; padding-right: 1rem; }
    .zn-grid { grid-template-columns: repeat(2, 1fr); }
    .zn-tag-grid { grid-template-columns: repeat(2, 1fr); }
    .zn-tag-grid .zn-card:first-child { grid-column: 1 / -1; }
    .zn-content h2, .zn-content h3, .zn-content h4 { margin: 1.75em 0 .625em; }
    .zn-content img { margin: 1.25em 0; }

    .zn-stats-grid { grid-template-columns: repeat(2, 1fr); }
    .zn-services-grid { grid-template-columns: 1fr; }
    .zn-service-featured { flex-direction: column; grid-column: span 1; }
    .zn-process-grid { grid-template-columns: repeat(2, 1fr); }
    .zn-skills-grid { grid-template-columns: repeat(2, 1fr); }
    .zn-about-hero-inner { grid-template-columns: 1fr; text-align: center; justify-items: center; }
    .zn-about-hero-img { width: 140px; height: 140px; }
    .zn-about-socials { justify-content: center; }
    .zn-foot-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
    .zn-foot-inner { padding-left: var(--zn-pad); padding-right: var(--zn-pad); }
    .zn-lead-row { grid-template-columns: 1fr; }
    .zn-related .zn-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .zn-share { flex-direction: row; flex-wrap: wrap; align-items: center; }
    .zn-author-box { flex-direction: column; }
    .zn-skills-grid { grid-template-columns: 1fr; }
    .zn-process-grid { grid-template-columns: 1fr; }
    .zn-foot-grid { grid-template-columns: 1fr; }
    .zn-grid { grid-template-columns: 1fr; }
    .zn-tag-grid { grid-template-columns: 1fr; }
    .zn-tag-grid .zn-card:first-child { grid-column: 1 / -1; }
}

@media print {
    .zn-head, .zn-sidebar, .zn-foot, .zn-share, .zn-progress, .scroll-top { display: none; }
}

/* ============================================================
   PAGE COMPONENTS — digunakan via HTML card di Ghost editor
   ============================================================ */

/* ----- Section wrapper ----- */
.zn-section { padding: 3rem 0; }
.zn-section-title { font-size: 1.75rem; font-weight: 800; color: var(--zn-dark); text-align: center; margin-bottom: .5rem; letter-spacing: -.03em; }
.zn-section-sub { font-size: 1rem; color: var(--zn-muted); text-align: center; margin-bottom: 2.5rem; max-width: 560px; margin-left: auto; margin-right: auto; }

/* ----- PRICING CARDS ----- */
/* Default: auto-fit. Override dengan zn-col-2 / zn-col-3 / zn-col-4 untuk jumlah kolom pasti */
.zn-pricing { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.5rem; margin: 2rem 0; }
.zn-pricing.zn-col-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
.zn-pricing.zn-col-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
.zn-pricing.zn-col-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }

.zn-pricing-card { background: var(--zn-bg); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); padding: 1.75rem; display: flex; flex-direction: column; gap: .875rem; position: relative; transition: box-shadow var(--zn-transition), transform var(--zn-transition); }
.zn-pricing-card:hover { box-shadow: 0 12px 40px rgba(0,0,0,.1); transform: translateY(-2px); }
.zn-pricing-card.zn-pricing-featured { border-color: var(--zn-primary); border-width: 2px; box-shadow: 0 4px 24px rgba(26,86,219,.15); }
.zn-pricing-card.zn-pricing-featured:hover { box-shadow: 0 16px 48px rgba(26,86,219,.22); transform: translateY(-3px); }
.zn-pricing-badge { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: var(--zn-primary); color: #fff; font-size: .7rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: .3rem .875rem; border-radius: 999px; white-space: nowrap; box-shadow: 0 2px 8px rgba(26,86,219,.35); }
.zn-pricing-name { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--zn-muted); }
.zn-pricing-price { display: flex; align-items: baseline; gap: .125rem; flex-wrap: wrap; }
.zn-pricing-currency { font-size: .9rem; font-weight: 700; color: var(--zn-dark); }
.zn-pricing-amount { font-size: 2.25rem; font-weight: 800; color: var(--zn-dark); letter-spacing: -.04em; line-height: 1; }
.zn-pricing-period { font-size: .8rem; color: var(--zn-muted); margin-left: .25rem; }
.zn-pricing-desc { font-size: .875rem; color: var(--zn-muted); line-height: 1.6; }
.zn-pricing-divider { border: none; border-top: 1px solid var(--zn-border); margin: .25rem 0; }
.zn-pricing-features { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .625rem; flex: 1; }
.zn-pricing-features li { font-size: .875rem; color: var(--zn-body); display: flex; align-items: flex-start; gap: .625rem; line-height: 1.5; }
.zn-pricing-features li::before { content: "✓"; color: #10b981; font-weight: 700; flex-shrink: 0; margin-top: .05em; }
.zn-pricing-features li.zn-no::before { content: "✗"; color: #cbd5e1; }
.zn-pricing-features li.zn-no { color: var(--zn-muted); }
.zn-pricing-card .zn-btn { margin-top: auto; text-align: center; justify-content: center; text-decoration: none !important; }

/* ----- FEATURE GRID ----- */
.zn-features { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.25rem; margin: 2rem 0; }
.zn-features.zn-col-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
.zn-features.zn-col-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
.zn-features.zn-col-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }

.zn-feature { background: var(--zn-bg); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); padding: 1.5rem; transition: box-shadow var(--zn-transition), border-color var(--zn-transition), transform var(--zn-transition); }
.zn-feature:hover { box-shadow: 0 6px 24px rgba(0,0,0,.08); border-color: var(--zn-primary); transform: translateY(-2px); }
.zn-feature-icon { font-size: 1.875rem; margin-bottom: .875rem; line-height: 1; display: block; }
.zn-feature-title { font-size: 1rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .375rem; }
.zn-feature-desc { font-size: .875rem; color: var(--zn-muted); line-height: 1.7; margin: 0; }

/* ----- COMPARISON TABLE ----- */
.zn-compare-wrap { overflow-x: auto; margin: 2rem 0; border-radius: var(--zn-radius-lg); border: 1px solid var(--zn-border); }
.zn-compare { width: 100%; border-collapse: collapse; font-size: .9rem; }
/* Tabel menggunakan template terpisah per jumlah kolom (lihat snippet HTML) */
.zn-compare thead th { background: var(--zn-dark); color: #fff; padding: .875rem 1.125rem; font-weight: 600; text-align: center; font-size: .875rem; }
.zn-compare thead th:first-child { text-align: left; background: var(--zn-bg-alt); color: var(--zn-body); font-weight: 500; }
.zn-compare thead th.zn-compare-featured { background: var(--zn-primary); }
.zn-compare tbody tr:hover td { background: #f0f7ff; }
.zn-compare tbody tr:nth-child(even) td { background: var(--zn-bg-alt); }
.zn-compare tbody tr:nth-child(even):hover td { background: #e8f0fe; }
.zn-compare tbody td { padding: .8rem 1.125rem; border-bottom: 1px solid var(--zn-border); color: var(--zn-body); text-align: center; transition: background .15s; }
.zn-compare tbody td:first-child { text-align: left; font-weight: 500; color: var(--zn-dark); }
.zn-compare tbody tr:last-child td { border-bottom: none; }
.zn-compare .zn-yes { color: #10b981; font-weight: 700; font-size: 1rem; }
.zn-compare .zn-no { color: #cbd5e1; font-size: 1rem; }
.zn-compare tfoot td { padding: .875rem 1.125rem; background: var(--zn-bg-alt); text-align: center; border-top: 2px solid var(--zn-border); }
.zn-compare tfoot td:first-child { text-align: left; }
.zn-compare tfoot .zn-btn { font-size: .8rem; padding: .4rem .875rem; text-decoration: none !important; }

/* ----- TEAM / AUTHOR CARDS ----- */
.zn-team { display: grid; gap: 1.5rem; margin: 2rem 0; }
.zn-team.zn-col-1 { grid-template-columns: 1fr; max-width: 360px; }
.zn-team.zn-col-2 { grid-template-columns: repeat(2, 1fr); }
.zn-team.zn-col-3 { grid-template-columns: repeat(3, 1fr); }
.zn-team:not(.zn-col-1):not(.zn-col-2):not(.zn-col-3) { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }

.zn-team-card { background: var(--zn-bg); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); padding: 1.75rem 1.5rem; text-align: center; transition: box-shadow var(--zn-transition), transform var(--zn-transition); }
.zn-team-card:hover { box-shadow: 0 8px 28px rgba(0,0,0,.1); transform: translateY(-2px); }
.zn-team-img { width: 88px; height: 88px; border-radius: 50%; object-fit: cover; margin: 0 auto 1rem; display: block; border: 3px solid var(--zn-border); }
.zn-team-img-placeholder { background: var(--zn-primary); color: #fff; font-weight: 700; font-size: 1.5rem; display: flex; align-items: center; justify-content: center; overflow: hidden; text-indent: -999px; }
.zn-team-name { font-size: 1.0625rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .25rem; }
.zn-team-role { font-size: .78rem; color: var(--zn-primary); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; margin-bottom: .75rem; }
.zn-team-bio { font-size: .825rem; color: var(--zn-muted); line-height: 1.65; margin-bottom: 1rem; }
.zn-team-social { display: flex; justify-content: center; gap: .75rem; flex-wrap: wrap; }
.zn-team-social a { color: var(--zn-muted); transition: color var(--zn-transition); display: flex; align-items: center; }
.zn-team-social a:hover { color: var(--zn-primary); }

/* ----- FAQ ACCORDION ----- */
.zn-faq { margin: 2rem 0; display: flex; flex-direction: column; gap: .625rem; }
.zn-faq-item { border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); overflow: hidden; transition: border-color var(--zn-transition); }
.zn-faq-item.is-open { border-color: var(--zn-primary); }
.zn-faq-q { width: 100%; background: var(--zn-bg); border: none; padding: 1.125rem 1.25rem; text-align: left; font-size: .9375rem; font-weight: 600; color: var(--zn-dark); cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 1rem; font-family: var(--zn-font); transition: background var(--zn-transition); }
.zn-faq-q:hover { background: var(--zn-bg-alt); }
.zn-faq-q::after { content: "+"; font-size: 1.375rem; font-weight: 300; color: var(--zn-muted); flex-shrink: 0; transition: transform .25s ease, color .15s; line-height: 1; }
.zn-faq-item.is-open .zn-faq-q::after { transform: rotate(45deg); color: var(--zn-primary); }
.zn-faq-item.is-open .zn-faq-q { background: var(--zn-bg-alt); color: var(--zn-primary); }
.zn-faq-a { display: none; padding: .25rem 1.25rem 1.5rem; font-size: .9rem; color: var(--zn-body); line-height: 1.8; }
.zn-faq-item.is-open .zn-faq-a { display: block; }

/* ----- FORM KOMPONEN ----- */
.zn-form-wrap { background: var(--zn-bg); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); padding: 2rem; margin: 2rem 0; }
.zn-form-title { font-size: 1.25rem; font-weight: 700; color: var(--zn-dark); margin-bottom: .375rem; }
.zn-form-sub { font-size: .875rem; color: var(--zn-muted); margin-bottom: 1.5rem; }
.zn-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-bottom: .75rem; }
.zn-form-field { display: flex; flex-direction: column; gap: .375rem; margin-bottom: .75rem; }
.zn-form-label { font-size: .8rem; font-weight: 600; color: var(--zn-dark); }
.zn-form-input { width: 100%; padding: .625rem .875rem; border: 1px solid var(--zn-border); border-radius: var(--zn-radius); font-size: .9rem; font-family: var(--zn-font); color: var(--zn-body); background: var(--zn-bg); transition: border-color var(--zn-transition); box-sizing: border-box; }
.zn-form-input:focus { outline: none; border-color: var(--zn-primary); box-shadow: 0 0 0 3px rgba(26,86,219,.08); }
textarea.zn-form-input { min-height: 120px; resize: vertical; }
.zn-form-note { font-size: .75rem; color: var(--zn-muted); margin-top: .75rem; }

/* ----- CTA BANNER ----- */
.zn-cta { background: linear-gradient(135deg, var(--zn-primary) 0%, #3b82f6 100%); border-radius: var(--zn-radius-lg); padding: 2.5rem 2rem; text-align: center; margin: 2rem 0; }
.zn-cta-title { font-size: 1.5rem; font-weight: 800; color: #fff; margin-bottom: .5rem; letter-spacing: -.025em; }
.zn-cta-desc { font-size: .9375rem; color: rgba(255,255,255,.85); margin-bottom: 1.5rem; }
.zn-cta a, .zn-cta .zn-btn { text-decoration: none !important; }
.zn-cta .zn-btn-primary { background: #fff; color: var(--zn-primary); border: none; transition: background var(--zn-transition), transform var(--zn-transition), box-shadow var(--zn-transition); }
.zn-cta .zn-btn-primary:hover { background: #f0f5ff; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.2); }

/* ----- STATS BAND ----- */
/* auto-fit: jumlah item berapapun akan menyesuaikan otomatis */
.zn-statsband { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 1px; background: var(--zn-border); border: 1px solid var(--zn-border); border-radius: var(--zn-radius-lg); overflow: hidden; margin: 2rem 0; }
.zn-statsband-item { background: var(--zn-bg); padding: 1.5rem 1rem; text-align: center; transition: background var(--zn-transition); }
.zn-statsband-item:hover { background: var(--zn-bg-alt); }
.zn-statsband-value { font-size: 2rem; font-weight: 800; color: var(--zn-primary); letter-spacing: -.04em; line-height: 1; display: block; }
.zn-statsband-label { font-size: .8rem; color: var(--zn-muted); margin-top: .375rem; display: block; }

/* Responsive komponen — desktop tetap sesuai zn-col-X, hanya mobile yang collapse */
@media (max-width: 600px) {
    /* Pricing: semua collapse ke 1 kolom di mobile */
    .zn-pricing.zn-col-2,
    .zn-pricing.zn-col-3,
    .zn-pricing.zn-col-4 { grid-template-columns: 1fr !important; }

    /* Feature: tetap 2 kolom di mobile kecuali 2 kolom asli */
    .zn-features.zn-col-3,
    .zn-features.zn-col-4 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }

    /* Team */
    .zn-team.zn-col-2,
    .zn-team.zn-col-3 { grid-template-columns: 1fr !important; }
    .zn-team.zn-col-1 { max-width: 100%; }

    .zn-form-grid { grid-template-columns: 1fr; }
    .zn-cta { padding: 2rem 1.25rem; }
    .zn-statsband { grid-template-columns: 1fr 1fr; }
}
