/* =========================================================================
   ketoan.org — theme stylesheet (class-based, no framework)
   Design tokens, layout and components extracted from the approved demo.
   ========================================================================= */

/* ---------- 1. Design tokens ---------- */
:root{
  --green:#0e4a37;        /* primary brand green */
  --green-700:#0a3a2c;
  --green-900:#0a2820;    /* footer */
  --mint:#7fd1ab;
  --mint-200:#a8e6cb;
  --mint-100:#bfe0d2;
  --mint-bg:#e7f1ec;
  --gold:#b7791f;
  --gold-bg:#f6edda;
  --gold-bd:#ecdcbc;
  --ink:#15201b;          /* headings */
  --ink-2:#2a352f;
  --body:#5a6661;         /* body text */
  --muted:#8a958f;
  --muted-2:#a4afaa;
  --slate:#3d4a44;
  --bd:#e3e9e6;           /* borders */
  --bd-2:#eef2f0;
  --bd-3:#eef3f0;
  --bg:#f5f7f6;           /* page background */
  --card:#fff;
  --ok:#0e9460;           /* "còn hiệu lực" */
  --max:1240px;
  --pad:28px;
  --radius:16px;
  --font-head:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-body:'Public Sans',system-ui,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,monospace;
  --shadow-card:0 12px 30px -16px rgba(14,74,55,.35);
}

/* ---------- 2. Base / reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
::selection{background:var(--green);color:#fff}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:var(--font-body)}
svg{flex-shrink:0}
@keyframes kf-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes kf-fade{from{opacity:0}to{opacity:1}}

/* ---------- 3. Layout ---------- */
.kt-wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.kt-page{min-height:100vh;background:var(--bg)}
.kt-section{max-width:var(--max);margin:0 auto;padding:64px var(--pad) 20px}
.kt-mono{font-family:var(--font-mono)}
.kt-scroll::-webkit-scrollbar{height:8px}
.kt-scroll::-webkit-scrollbar-thumb{background:#cdd8d2;border-radius:8px}

.kt-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.kt-head h2{font-family:var(--font-head);font-weight:800;font-size:30px;letter-spacing:-.8px;color:var(--ink)}
.kt-head p{font-size:15.5px;color:var(--body);margin-top:6px}
.kt-link{font-size:14.5px;font-weight:700;color:var(--green);cursor:pointer;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;transition:gap .15s}
.kt-link:hover{gap:9px}

/* ---------- 4. Top strip ---------- */
.kt-topbar{background:var(--green-700);color:var(--mint-100);font-size:12.5px;letter-spacing:.2px}
.kt-topbar .kt-wrap{padding-top:7px;padding-bottom:7px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.kt-topbar .kt-grp{display:flex;align-items:center;gap:18px}
.kt-topbar .kt-dot{width:6px;height:6px;border-radius:50%;background:var(--mint);display:inline-block}
.kt-topbar .kt-pipe{opacity:.5}
.kt-topbar span.kt-flex{display:flex;align-items:center;gap:7px}

/* ---------- 5. Header / nav ---------- */
.kt-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--bd)}
.kt-header .kt-wrap{height:70px;display:flex;align-items:center;gap:30px}
.kt-logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.kt-logo .kt-mark{width:38px;height:38px;border-radius:10px;background:var(--green);display:flex;align-items:flex-end;justify-content:center;gap:3px;padding:0 0 10px}
.kt-logo .kt-mark i{width:4px;border-radius:2px;display:block}
.kt-logo .kt-mark i:nth-child(1){height:10px;background:var(--mint)}
.kt-logo .kt-mark i:nth-child(2){height:16px;background:#fff}
.kt-logo .kt-mark i:nth-child(3){height:13px;background:var(--gold)}
.kt-logo .kt-name{font-family:var(--font-head);font-weight:800;font-size:20px;letter-spacing:-.5px;color:var(--ink)}
.kt-logo .kt-name b{color:var(--green);font-weight:800}
/* If a custom logo is set via Customizer, keep it small in the header. */
.kt-header .kt-logo .custom-logo,.kt-header .custom-logo{height:40px;width:auto;max-height:40px;display:block}
.kt-header .kt-logo{max-height:46px}

.kt-nav{display:flex;align-items:center;gap:3px;margin-left:6px}
.kt-nav a{padding:9px 13px;border-radius:8px;font-size:14.5px;font-weight:600;color:var(--slate);white-space:nowrap;transition:background .15s}
.kt-nav a:hover{background:var(--bd-3)}
.kt-nav a.current,.kt-nav li.current-menu-item>a,.kt-nav li.current_page_item>a{color:var(--green);background:var(--bd-3)}
.kt-nav ul{list-style:none;display:flex;align-items:center;gap:3px}

.kt-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.kt-iconbtn{width:40px;height:40px;border-radius:9px;border:1px solid var(--bd);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}
.kt-iconbtn:hover{background:var(--bg)}
.kt-ghost{padding:10px 14px;border-radius:9px;font-size:14.5px;font-weight:600;color:var(--ink);cursor:pointer;transition:background .15s}
.kt-ghost:hover{background:var(--bd-3)}
.kt-cta{padding:10px 18px;border-radius:9px;font-size:14.5px;font-weight:700;color:#fff;background:var(--green);cursor:pointer;white-space:nowrap;transition:background .15s}
.kt-cta:hover{background:var(--green-700)}

.kt-burger{display:none;width:40px;height:40px;border-radius:9px;border:1px solid var(--bd);background:#fff;cursor:pointer;align-items:center;justify-content:center}

/* ---------- 6. Buttons / forms ---------- */
.kt-searchbar{display:flex;border:2px solid var(--bd);border-radius:13px;padding:5px;max-width:520px;transition:border-color .15s;background:#fff}
.kt-searchbar:focus-within{border-color:var(--green)}
.kt-searchbar input{flex:1;border:none;outline:none;font-size:16px;font-family:var(--font-body);padding:13px 16px;background:transparent;color:var(--ink)}
.kt-searchbar .kt-ico{display:flex;align-items:center;padding-left:14px;color:var(--muted)}
.kt-searchbar button{background:var(--green);color:#fff;border:none;border-radius:9px;padding:0 24px;font-weight:700;font-size:15px;cursor:pointer;transition:background .15s}
.kt-searchbar button:hover{background:var(--green-700)}

/* tag pill */
.kt-tag{font-family:var(--font-mono);font-size:11px;font-weight:600;padding:4px 8px;border-radius:6px;white-space:nowrap;color:var(--green);background:var(--mint-bg)}
.kt-tag.is-gold{color:var(--gold);background:var(--gold-bg)}
.kt-status{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--ok);font-weight:600}
.kt-status .kt-d{width:6px;height:6px;border-radius:50%;background:var(--ok)}

/* ---------- 7. Hero ---------- */
.kt-hero{background:#fff;border-bottom:1px solid var(--bd)}
.kt-hero .kt-wrap{padding:64px var(--pad);display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.kt-badge{display:inline-flex;align-items:center;gap:8px;background:var(--mint-bg);color:var(--green);padding:6px 13px;border-radius:100px;font-size:13px;font-weight:700;margin-bottom:22px}
.kt-hero h1{font-family:var(--font-head);font-weight:800;font-size:50px;line-height:1.05;letter-spacing:-1.5px;color:var(--ink);margin-bottom:20px;text-wrap:balance}
.kt-hero .kt-lead{font-size:18px;line-height:1.6;color:var(--body);margin-bottom:30px;max-width:480px}
.kt-hero-stats{display:flex;gap:30px;margin-top:34px;flex-wrap:wrap}
.kt-stat .kt-num{font-family:var(--font-head);font-weight:800;font-size:26px;color:var(--green)}
.kt-stat .kt-lbl{font-size:13px;color:var(--muted);font-weight:500}

.kt-panel{background:var(--bg);border:1px solid var(--bd);border-radius:18px;padding:22px}
.kt-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kt-panel-head .kt-eyebrow{font-size:13px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted)}
.kt-panel-head .kt-hot{font-family:var(--font-mono);font-size:12px;color:var(--gold);font-weight:600}
.kt-quick{display:flex;flex-direction:column;gap:9px}
.kt-quick a{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--bd);border-radius:11px;padding:13px 15px;transition:all .15s}
.kt-quick a:hover{border-color:var(--green);transform:translateX(3px)}
.kt-quick .kt-t{font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.35}

/* ---------- 8. Category cards ---------- */
.kt-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.kt-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kt-cat{display:block;background:#fff;border:1px solid var(--bd);border-radius:16px;padding:24px;transition:all .18s;position:relative;overflow:hidden}
.kt-cat:hover{border-color:var(--green);box-shadow:var(--shadow-card);transform:translateY(-2px)}
.kt-cat-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.kt-cat .kt-glyph{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:600;font-size:15px;background:var(--mint-bg);color:var(--green)}
.kt-cat.is-gold .kt-glyph{background:var(--gold-bg);color:var(--gold)}
.kt-cat .kt-count{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--muted)}
.kt-cat h3{font-family:var(--font-head);font-weight:700;font-size:18px;color:var(--ink);margin-bottom:6px}
.kt-cat p{font-size:14px;line-height:1.5;color:var(--body)}

/* ---------- 9. Standards cards (home) ---------- */
.kt-std{display:block;background:#fff;border:1px solid var(--bd);border-radius:14px;padding:18px;transition:all .15s}
.kt-std:hover{border-color:var(--gold);box-shadow:0 10px 26px -16px rgba(0,0,0,.3)}
.kt-std-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.kt-code{font-family:var(--font-mono);font-weight:600;font-size:13px;color:#fff;background:var(--green);padding:5px 9px;border-radius:7px}
.kt-code.is-ifrs{background:var(--gold)}
.kt-std h3{font-size:14.5px;font-weight:600;line-height:1.4;color:var(--ink);min-height:40px}
.kt-std .kt-upd{font-size:12.5px;color:var(--muted);margin-top:10px;font-family:var(--font-mono)}
.kt-eff{width:7px;height:7px;border-radius:50%;background:var(--mint)}

/* ---------- 10. Latest docs list ---------- */
.kt-two-col{max-width:var(--max);margin:0 auto;padding:50px var(--pad);display:grid;grid-template-columns:1.6fr 1fr;gap:40px}
.kt-list{display:flex;flex-direction:column;gap:2px;background:#fff;border:1px solid var(--bd);border-radius:16px;overflow:hidden}
.kt-doc-row{display:flex;gap:16px;padding:18px 20px;border-bottom:1px solid var(--bd-2);transition:background .15s}
.kt-doc-row:last-child{border-bottom:none}
.kt-doc-row:hover{background:#f7faf8}
.kt-doc-row .kt-tag{padding:5px 9px;border-radius:7px;height:fit-content}
.kt-doc-row .kt-b{flex:1;min-width:0}
.kt-doc-row h3{font-size:16px;font-weight:600;line-height:1.4;color:var(--ink);margin-bottom:5px}
.kt-doc-meta{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.kt-doc-meta .kt-sep{color:#cdd8d2}

/* templates list */
.kt-tpl-list{display:flex;flex-direction:column;gap:10px}
.kt-tpl{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--bd);border-radius:12px;padding:14px;transition:all .15s}
.kt-tpl:hover{border-color:var(--green)}
.kt-tpl .kt-ext{width:42px;height:42px;border-radius:9px;background:var(--mint-bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--green);flex-shrink:0}
.kt-tpl .kt-b{flex:1;min-width:0}
.kt-tpl h3{font-size:14px;font-weight:600;color:var(--ink);line-height:1.35;margin-bottom:3px}
.kt-tpl .kt-dl{font-size:12.5px;color:var(--muted);font-family:var(--font-mono)}

/* ---------- 11. Courses strip ---------- */
.kt-courses{background:var(--green);position:relative;overflow:hidden}
.kt-courses .kt-dots{position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.05) 1px,transparent 0);background-size:24px 24px}
.kt-courses .kt-wrap{padding:56px var(--pad);position:relative}
.kt-courses .kt-head h2{color:#fff}
.kt-courses .kt-head p{color:var(--mint-100)}
.kt-courses .kt-link{color:var(--mint-200)}
.kt-course{display:block;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:16px;overflow:hidden;transition:all .15s}
.kt-course:hover{background:rgba(255,255,255,.1)}
.kt-course .kt-cover{height:120px;display:flex;align-items:flex-end;padding:14px}
.kt-course .kt-lessons{background:rgba(0,0,0,.35);color:#fff;font-family:var(--font-mono);font-size:11.5px;font-weight:600;padding:4px 9px;border-radius:6px}
.kt-course .kt-cb{padding:18px}
.kt-course h3{font-family:var(--font-head);font-weight:700;font-size:17px;color:#fff;line-height:1.35;margin-bottom:8px}
.kt-course .kt-cl{font-size:13.5px;color:var(--mint-100)}

/* ---------- 12. Trust bar ---------- */
.kt-trust{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.kt-trust .kt-num{font-family:var(--font-head);font-weight:800;font-size:38px;color:var(--green);letter-spacing:-1px}
.kt-trust .kt-lbl{font-size:14.5px;color:var(--body);font-weight:500;margin-top:4px}

/* ---------- 13. Breadcrumb ---------- */
.kt-crumb{font-size:13px;color:var(--muted);margin-bottom:14px}
.kt-crumb a{color:var(--muted)}
.kt-crumb a:hover{color:var(--green)}
.kt-crumb .kt-here{color:var(--ink);font-weight:600}
.kt-crumb .kt-slash{margin:0 8px}

/* ---------- 14. Browse / archive ---------- */
.kt-browse-head{background:#fff;border-bottom:1px solid var(--bd)}
.kt-browse-head .kt-wrap{padding:26px var(--pad) 28px}
.kt-browse-head .kt-searchbar{max-width:720px}
.kt-browse-grid{max-width:var(--max);margin:0 auto;padding:32px var(--pad) 70px;display:grid;grid-template-columns:262px 1fr;gap:32px;align-items:start}
.kt-aside{background:#fff;border:1px solid var(--bd);border-radius:16px;padding:6px 4px;position:sticky;top:90px}
.kt-fgroup{padding:16px 18px;border-bottom:1px solid var(--bd-2)}
.kt-fgroup:last-of-type{border-bottom:none}
.kt-fgroup h4{font-family:var(--font-head);font-weight:700;font-size:14px;color:var(--ink);margin-bottom:12px}
.kt-fopts{display:flex;flex-direction:column;gap:11px}
.kt-fopt{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--slate)}
.kt-fopt .kt-box{width:18px;height:18px;border-radius:5px;border:2px solid #cdd8d2;background:#fff;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.kt-fopt.is-on .kt-box{border-color:var(--green);background:var(--green)}
.kt-fopt .kt-fl{flex:1}
.kt-fopt .kt-fc{font-size:12px;color:var(--muted-2);font-family:var(--font-mono)}
.kt-fclear{width:100%;padding:9px;border:1px solid var(--bd);background:var(--bg);border-radius:9px;font-size:13.5px;font-weight:600;color:var(--body);cursor:pointer;font-family:var(--font-body)}

.kt-results-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:12px}
.kt-results-top .kt-cnt{font-size:14.5px;color:var(--body)}
.kt-results-top .kt-cnt strong{color:var(--ink);font-family:var(--font-mono)}
.kt-sort{display:flex;align-items:center;gap:8px}
.kt-sort .kt-sl{font-size:13.5px;color:var(--muted)}
.kt-sort .kt-pills{display:flex;background:#fff;border:1px solid var(--bd);border-radius:9px;padding:3px;gap:2px}
.kt-sort .kt-pills a{padding:6px 12px;border:none;background:transparent;color:var(--body);border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}
.kt-sort .kt-pills a.is-on{background:var(--green);color:#fff}

.kt-cards{display:flex;flex-direction:column;gap:14px}
.kt-rcard{background:#fff;border:1px solid var(--bd);border-radius:14px;padding:22px 24px;transition:all .15s}
.kt-rcard:hover{border-color:var(--green);box-shadow:0 10px 28px -18px rgba(14,74,55,.4)}
.kt-rcard-top{display:flex;align-items:center;gap:10px;margin-bottom:11px;flex-wrap:wrap}
.kt-rcard h3{font-family:var(--font-head);font-weight:700;font-size:19px;color:var(--ink);line-height:1.35;margin-bottom:8px}
.kt-rcard h3 a{color:inherit}
.kt-rcard h3 a:hover{color:var(--green)}
.kt-rcard p{font-size:14.5px;line-height:1.6;color:var(--body);margin-bottom:14px}
.kt-rcard-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--muted);font-family:var(--font-mono);flex-wrap:wrap}
.kt-rcard-meta .kt-sep{color:#d4ddd8}

/* pagination */
.kt-pager{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:32px;flex-wrap:wrap}
.kt-pager a,.kt-pager span{min-width:40px;height:40px;border-radius:9px;border:1px solid var(--bd);background:#fff;color:var(--slate);cursor:pointer;font-size:14px;font-family:var(--font-mono);display:flex;align-items:center;justify-content:center;padding:0 8px}
.kt-pager .current{background:var(--green);color:#fff;border-color:var(--green);font-weight:700}
.kt-pager a:hover{border-color:var(--green)}
.kt-pager .dots{border:none;background:transparent;color:var(--muted-2);cursor:default}

/* ---------- 15. Single / document ---------- */
.kt-doc{max-width:var(--max);margin:0 auto;padding:28px var(--pad) 70px}
.kt-doc-grid{display:grid;grid-template-columns:1fr 300px;gap:36px;align-items:start}
.kt-article{background:#fff;border:1px solid var(--bd);border-radius:18px;padding:44px 48px}
.kt-article-tags{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.kt-article-tags .kt-tag{padding:5px 11px;border-radius:7px;font-size:12px}
.kt-article h1{font-family:var(--font-head);font-weight:800;font-size:33px;line-height:1.2;letter-spacing:-.6px;color:var(--ink);margin-bottom:14px;text-wrap:balance}
.kt-article-meta{display:flex;align-items:center;gap:16px;font-size:13.5px;color:var(--muted);font-family:var(--font-mono);padding-bottom:24px;margin-bottom:28px;border-bottom:1px solid var(--bd-2);flex-wrap:wrap}
.kt-article-meta .kt-sep{color:#d4ddd8}
.kt-actionbar{display:flex;gap:10px;margin-bottom:32px;flex-wrap:wrap}
.kt-act{display:flex;align-items:center;gap:8px;padding:11px 18px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font-body);background:#fff;color:var(--ink);border:1px solid var(--bd)}
.kt-act.is-primary{background:var(--green);color:#fff;border:none;font-weight:700}

.kt-prose{font-size:16px;line-height:1.75;color:var(--ink-2)}
.kt-prose h2{font-family:var(--font-head);font-weight:700;font-size:21px;color:var(--ink);margin:28px 0 12px}
.kt-prose h3{font-family:var(--font-head);font-weight:700;font-size:18px;color:var(--ink);margin:22px 0 10px}
.kt-prose p{margin-bottom:20px}
.kt-prose ul,.kt-prose ol{margin:0 0 20px 22px}
.kt-prose li{margin-bottom:8px}
.kt-prose a{color:var(--green);text-decoration:underline;text-underline-offset:2px}
.kt-prose img{border-radius:12px;margin:18px 0}
.kt-prose blockquote{background:#f7faf8;border-left:3px solid var(--green);border-radius:0 10px 10px 0;padding:18px 22px;margin:24px 0;font-size:15px;color:var(--slate)}
.kt-prose blockquote p{margin:0}
.kt-prose table{width:100%;border-collapse:collapse;font-size:14.5px;margin:18px 0;border:1px solid var(--bd);border-radius:12px;overflow:hidden}
.kt-prose thead tr{background:var(--bg)}
.kt-prose th{text-align:left;padding:12px 16px;font-family:var(--font-mono);font-weight:600;color:var(--body);font-size:13px;border-bottom:1px solid var(--bd)}
.kt-prose td{padding:11px 16px;border-bottom:1px solid var(--bd-2)}
.kt-prose tbody tr:last-child td{border-bottom:none}

.kt-sidebar{position:sticky;top:90px;display:flex;flex-direction:column;gap:16px}
.kt-box{background:#fff;border:1px solid var(--bd);border-radius:16px;padding:20px}
.kt-box h4{font-family:var(--font-head);font-weight:700;font-size:14px;color:var(--ink);margin-bottom:14px}
.kt-info{display:flex;flex-direction:column;gap:11px}
.kt-info .kt-row{display:flex;justify-content:space-between;gap:12px;font-size:13.5px}
.kt-info .kt-k{color:var(--muted)}
.kt-info .kt-v{color:var(--ink);font-weight:600;text-align:right;font-family:var(--font-mono);font-size:12.5px}
.kt-toc{display:flex;flex-direction:column}
.kt-toc a{font-size:13.5px;color:var(--slate);padding:8px 0;border-bottom:1px solid #f2f5f3;display:flex;gap:9px}
.kt-toc a:last-child{border-bottom:none}
.kt-toc a:hover{color:var(--green)}
.kt-toc .kt-i{font-family:var(--font-mono);color:var(--gold);font-size:12px;flex-shrink:0}
.kt-related{display:flex;flex-direction:column;gap:10px}
.kt-related a{display:block;padding:10px 12px;background:#f7faf8;border-radius:9px}
.kt-related a:hover{background:var(--bd-3)}
.kt-related .kt-rc{font-family:var(--font-mono);font-size:11.5px;font-weight:600;color:var(--gold);margin-bottom:3px}
.kt-related .kt-rt{font-size:13px;color:var(--ink);line-height:1.35;font-weight:500}

/* ---------- 16. Standards page ---------- */
.kt-hero-dark{background:var(--green);position:relative;overflow:hidden}
.kt-hero-dark .kt-dots{position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.05) 1px,transparent 0);background-size:24px 24px}
.kt-hero-dark .kt-wrap{padding:48px var(--pad) 40px;position:relative}
.kt-hero-dark .kt-crumb,.kt-hero-dark .kt-crumb a{color:var(--mint-200)}
.kt-hero-dark .kt-here{color:#fff}
.kt-hero-dark h1{font-family:var(--font-head);font-weight:800;font-size:38px;letter-spacing:-1px;color:#fff;margin-bottom:10px}
.kt-hero-dark p{font-size:16.5px;color:var(--mint-100);max-width:560px;line-height:1.5}

.kt-tabs{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.kt-tab{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:14px 22px;border-radius:13px;border:1.5px solid var(--bd);background:#fff;cursor:pointer;transition:all .15s}
.kt-tab .kt-tl{font-family:var(--font-head);font-weight:700;font-size:15.5px;color:var(--ink);white-space:nowrap}
.kt-tab .kt-ts{font-size:12.5px;color:var(--muted);font-family:var(--font-mono);white-space:nowrap}
.kt-tab.is-on{background:var(--green);border-color:var(--green)}
.kt-tab.is-on .kt-tl{color:#fff}
.kt-tab.is-on .kt-ts{color:var(--mint-200)}
.kt-stdtable{background:#fff;border:1px solid var(--bd);border-radius:16px;overflow:hidden}
.kt-stdtable .kt-rows{display:grid;grid-template-columns:repeat(2,1fr)}
.kt-stdrow{display:flex;align-items:center;gap:16px;padding:16px 22px;border-bottom:1px solid var(--bd-2);border-right:1px solid var(--bd-2);transition:background .15s}
.kt-stdrow:hover{background:#f7faf8}
.kt-stdrow .kt-st{flex:1;font-size:15px;color:var(--ink);font-weight:500;line-height:1.35}
.kt-note{display:flex;align-items:center;gap:12px;margin-top:20px;background:var(--gold-bg);border:1px solid var(--gold-bd);border-radius:12px;padding:16px 20px}
.kt-note .kt-i{width:32px;height:32px;border-radius:8px;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:600;flex-shrink:0}
.kt-note p{margin:0;font-size:14px;color:#6b5320;line-height:1.5}

/* ---------- 17. Footer ---------- */
.kt-footer{background:var(--green-900);color:#9bbcb0;border-top:1px solid var(--green)}
.kt-footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-top:54px;padding-bottom:36px}
.kt-footer .kt-logo .kt-name{color:#fff}
.kt-footer .kt-logo .kt-name b{color:var(--mint)}
.kt-footer .kt-about{font-size:14px;line-height:1.6;max-width:280px;color:#7fa294;margin-top:16px}
.kt-footer .kt-logo{margin-bottom:0}
.kt-fcol h4{font-family:var(--font-head);font-weight:700;font-size:14px;color:#fff;margin-bottom:14px;letter-spacing:.3px}
.kt-fcol .kt-flinks{display:flex;flex-direction:column;gap:9px}
.kt-fcol a{font-size:14px;color:#9bbcb0}
.kt-fcol a:hover{color:#fff}
.kt-footer-bot{border-top:1px solid var(--green)}
.kt-footer-bot .kt-wrap{padding:20px var(--pad);display:flex;align-items:center;justify-content:space-between;font-size:13px;color:#6b8c7f;flex-wrap:wrap;gap:10px}
.kt-footer-bot .kt-legal{display:flex;gap:20px}
.kt-footer-bot a{color:#6b8c7f}
.kt-footer-bot a:hover{color:#fff}

/* ---------- 18. 404 / empty ---------- */
.kt-empty{max-width:680px;margin:0 auto;padding:90px var(--pad);text-align:center}
.kt-empty .kt-code{display:inline-block;background:var(--green);color:#fff;font-family:var(--font-head);font-weight:800;font-size:54px;letter-spacing:-1px;padding:12px 26px;border-radius:18px;margin-bottom:24px}
.kt-empty h1{font-family:var(--font-head);font-weight:800;font-size:30px;color:var(--ink);margin-bottom:12px;letter-spacing:-.6px}
.kt-empty p{font-size:16px;color:var(--body);margin-bottom:28px;line-height:1.6}
.kt-empty .kt-searchbar{margin:0 auto 24px}

/* ---------- 19. Utilities ---------- */
.kt-mt-50{margin-top:50px}
.kt-pt-0{padding-top:0}
.kt-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.kt-comments{max-width:var(--max);margin:0 auto;padding:0 var(--pad) 60px}

/* ---------- 19b. E-E-A-T: review line, author box, FAQ ---------- */
.kt-review{display:inline-flex;align-items:center;gap:8px;background:#eaf6f0;border:1px solid #cfe9dd;color:#0a6b4a;font-size:13px;font-weight:600;padding:7px 13px;border-radius:9px;margin:0 0 22px}
.kt-review strong{font-weight:700}

.kt-authorbox{position:relative;display:flex;gap:20px;background:linear-gradient(180deg,#f7faf8,#fff 70%);border:1px solid var(--bd);border-radius:18px;padding:26px 26px 24px;margin-top:32px;overflow:hidden}
.kt-authorbox::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--mint),var(--green))}
.kt-ab-avatar{position:relative;width:72px;height:72px;flex-shrink:0}
.kt-ab-initials{width:72px;height:72px;border-radius:50%;background:linear-gradient(145deg,#11785a,#0a3a2c);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:26px;letter-spacing:.5px;box-shadow:0 8px 18px -8px rgba(14,74,55,.6)}
.kt-ab-badge{position:absolute;right:-2px;bottom:-2px;width:24px;height:24px;border-radius:50%;background:var(--ok);border:3px solid #fff;display:flex;align-items:center;justify-content:center}
.kt-ab-body{flex:1;min-width:0}
.kt-ab-eyebrow{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--gold);margin-bottom:5px}
.kt-ab-name{font-family:var(--font-head);font-weight:800;font-size:19px;color:var(--ink);margin-bottom:2px;line-height:1.2}
.kt-ab-name a{color:inherit}
.kt-ab-name a:hover{color:var(--green)}
.kt-ab-role{font-size:13.5px;color:var(--green);font-weight:700;margin-bottom:10px}
.kt-ab-bio{font-size:14.5px;line-height:1.65;color:var(--body);margin-bottom:16px}
.kt-ab-foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.kt-ab-btn{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff;font-size:13.5px;font-weight:700;padding:9px 16px;border-radius:9px;transition:background .15s}
.kt-ab-btn:hover{background:var(--green-700)}
.kt-ab-count{font-size:13px;color:var(--muted)}
.kt-ab-count strong{color:var(--ink);font-family:var(--font-mono)}
@media (max-width:520px){.kt-authorbox{flex-direction:column;gap:14px}}

.kt-faq{margin-top:36px}
.kt-faq>h2{font-family:var(--font-head);font-weight:700;font-size:21px;color:var(--ink);margin-bottom:14px}
.kt-faq-item{background:#fff;border:1px solid var(--bd);border-radius:12px;padding:4px 18px;margin-bottom:10px}
.kt-faq-item summary{font-weight:600;font-size:15.5px;color:var(--ink);cursor:pointer;padding:14px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.kt-faq-item summary::-webkit-details-marker{display:none}
.kt-faq-item summary::after{content:"+";font-family:var(--font-mono);font-size:20px;color:var(--green);flex-shrink:0}
.kt-faq-item[open] summary::after{content:"–"}
.kt-faq-a{font-size:14.5px;line-height:1.7;color:var(--ink-2);padding:0 0 16px}
.kt-faq-a p{margin:0 0 10px}

.kt-disclaimer{font-size:13px;color:var(--muted);line-height:1.6;border-top:1px solid var(--bd-2);margin-top:32px;padding-top:18px}
.kt-disclaimer a{color:var(--green);text-decoration:underline}

.kt-sources{margin-top:24px;background:#f7faf8;border:1px solid var(--bd-2);border-radius:12px;padding:16px 20px}
.kt-sources h2{font-family:var(--font-head);font-weight:700;font-size:16px;color:var(--ink);margin:0 0 10px}
.kt-sources ul{margin:0 0 0 18px}
.kt-sources li{font-size:13.5px;color:var(--body);margin-bottom:6px}
.kt-sources a{color:var(--green)}

/* footer NAP */
.kt-nap{margin-top:16px;display:flex;flex-direction:column;gap:7px;font-size:13.5px;color:#9bbcb0}
.kt-nap .kt-nap-row{display:flex;align-items:flex-start;gap:9px}
.kt-nap a{color:#9bbcb0}
.kt-nap a:hover{color:#fff}
.kt-nap svg{margin-top:2px;flex-shrink:0}

/* ---------- 20. Responsive ---------- */
@media (max-width:1080px){
  .kt-hero .kt-wrap{grid-template-columns:1fr;gap:36px}
  .kt-hero h1{font-size:42px}
  .kt-grid-4{grid-template-columns:repeat(2,1fr)}
  .kt-two-col{grid-template-columns:1fr;gap:32px}
  .kt-doc-grid{grid-template-columns:1fr}
  .kt-sidebar{position:static}
  .kt-browse-grid{grid-template-columns:1fr}
  .kt-aside{position:static}
  .kt-footer-top{grid-template-columns:1fr 1fr;gap:28px}
}
@media (max-width:760px){
  :root{--pad:18px}
  .kt-nav,.kt-actions .kt-ghost,.kt-topbar .kt-grp:first-child{display:none}
  .kt-burger{display:flex}
  .kt-nav.is-open{display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;align-items:stretch;background:#fff;border-bottom:1px solid var(--bd);padding:10px 18px;gap:2px;margin:0}
  .kt-nav.is-open ul{flex-direction:column;align-items:stretch;gap:2px;width:100%}
  .kt-nav.is-open a{display:block}
  .kt-grid-3,.kt-grid-4,.kt-trust{grid-template-columns:1fr 1fr}
  .kt-hero h1{font-size:34px;letter-spacing:-1px}
  .kt-hero .kt-lead{font-size:16px}
  .kt-article{padding:26px 22px}
  .kt-article h1{font-size:26px}
  .kt-footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:480px){
  .kt-grid-3,.kt-grid-4,.kt-trust,.kt-stdtable .kt-rows,.kt-footer-top{grid-template-columns:1fr}
  .kt-head h2{font-size:24px}
  .kt-hero h1{font-size:29px}
}
