/*
Theme Name: Cốc Vũ — Cute & Friendly
Theme URI: https://cocvu.com
Description: Theme child gọn nhẹ của GeneratePress cho CocVu.com — giao diện "Cute & Friendly". Không Bootstrap, không jQuery. Toàn bộ giao diện viết bằng CSS/Vanilla JS thuần.
Author: Cốc Vũ
Author URI: https://cocvu.com
Template: generatepress
Version: 1.0.0
Requires PHP: 7.4
Text Domain: cocvu
*/

/* ============================================================
   1. DESIGN TOKENS
   ============================================================ */
:root{
  --bg:#FFF4EC; --ink:#3A2417; --muted:#9A8472;
  --orange:#FF7A45; --coral:#FF9E8A; --pink:#FFC9C2; --mint:#9FE0C7;
  --yellow:#FFD66B; --cream:#FFE7D6; --sky:#B8D8F0;
  --disp:"Baloo 2",system-ui,sans-serif;
  --sans:"Nunito",system-ui,sans-serif;
  --maxw:1160px;
  --soft:0 18px 40px rgba(255,122,69,.16);
}

/* ============================================================
   2. RESET / BASE
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}
button{font-family:inherit;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.disp{font-family:var(--disp);font-weight:800;letter-spacing:-.01em;}
.skip-link{position:absolute;left:-9999px;}
.skip-link:focus{left:16px;top:16px;background:#fff;padding:10px 16px;border-radius:12px;z-index:200;box-shadow:var(--soft);}

/* image placeholder (when post has no thumbnail) */
.ph{background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.5), transparent 60%),
    repeating-linear-gradient(45deg,rgba(255,122,69,.10),rgba(255,122,69,.10) 12px,transparent 12px,transparent 24px);
  display:flex;align-items:center;justify-content:center;color:rgba(58,36,23,.4);
  font-family:var(--disp);font-weight:600;font-size:14px;}
.pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--disp);font-weight:700;font-size:14px;padding:7px 16px;border-radius:999px;white-space:nowrap;}

/* ============================================================
   3. MASCOT (pure CSS cup character)
   ============================================================ */
.mascot{position:relative;display:inline-block;line-height:0;}
.cup{width:var(--cs,40px);height:calc(var(--cs,40px)*1.05);background:var(--orange);border-radius:30% 30% 42% 42%/22% 22% 60% 60%;position:relative;box-shadow:inset 0 -6px 0 rgba(0,0,0,.07);}
.cup::after{content:"";position:absolute;right:-22%;top:24%;width:34%;height:42%;border:5px solid var(--orange);border-left:none;border-radius:0 60% 60% 0;}
.cup .eye{position:absolute;top:34%;width:13%;height:13%;background:#3A2417;border-radius:50%;}
.cup .eye.l{left:28%;}.cup .eye.r{left:55%;}
.cup .mouth{position:absolute;top:52%;left:38%;width:24%;height:14%;border:0 solid #3A2417;border-bottom-width:4px;border-radius:0 0 60% 60%;}
.cup .blush{position:absolute;top:46%;width:13%;height:9%;background:#FF6F6F;opacity:.45;border-radius:50%;}
.cup .blush.l{left:18%;}.cup .blush.r{left:66%;}

/* ============================================================
   4. HEADER / NAV
   ============================================================ */
.site-header{position:sticky;top:0;z-index:50;background:var(--bg);}

/* top bar */
.topbar{border-bottom:1px solid rgba(154,132,114,.16);}
.topbar-in{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:9px 0;font-weight:700;font-size:13px;color:var(--muted);}
.topbar-tag{display:inline-flex;align-items:center;gap:6px;}
.topbar-social{display:inline-flex;gap:8px;}
.topbar-social a{width:25px;height:25px;border-radius:8px;background:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:var(--ink);box-shadow:0 4px 10px rgba(58,36,23,.06);transition:.16s;}
.topbar-social a:hover{transform:translateY(-2px);color:var(--orange);}

/* nav pill */
.site-header>.wrap{position:relative;padding-top:14px;padding-bottom:14px;}
.nav{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:999px;padding:10px 12px 10px 22px;box-shadow:0 8px 26px rgba(255,122,69,.14);gap:14px;}
.brand{font-family:var(--disp);font-weight:800;font-size:21px;display:flex;align-items:center;gap:11px;flex-shrink:0;}
.brand-name{white-space:nowrap;}
.brand-logo{height:40px;width:auto;display:block;}
.footer-brand .brand-logo{height:46px;}

.navlinks{display:flex;gap:24px;font-weight:700;font-size:15px;list-style:none;margin:0;padding:0;}
.navlinks>li{position:relative;}
.navlinks a{color:var(--ink);opacity:.72;transition:.16s;display:inline-flex;align-items:center;}
.navlinks a:hover,.navlinks .current-menu-item>a,.navlinks .current-menu-parent>a,.navlinks .current-menu-ancestor>a{opacity:1;color:var(--orange);}
.navlinks .menu-item-has-children>a::after{content:"⌄";font-size:1em;line-height:1;margin-left:5px;opacity:.55;transform:translateY(-2px);}
.navlinks .sub-menu{display:none;position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%);background:#fff;border-radius:18px;padding:10px;box-shadow:var(--soft);min-width:210px;flex-direction:column;gap:2px;z-index:60;list-style:none;}
.navlinks .sub-menu::before{content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(45deg);width:14px;height:14px;background:#fff;border-radius:3px;}
.navlinks li:hover>.sub-menu,.navlinks li:focus-within>.sub-menu{display:flex;}
.navlinks .sub-menu a{padding:9px 14px;border-radius:12px;opacity:.85;white-space:nowrap;font-size:14.5px;}
.navlinks .sub-menu a:hover{background:var(--bg);opacity:1;}

.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.nav-icon{background:var(--bg);border:none;width:44px;height:44px;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--ink);transition:.16s;}
.nav-icon:hover{background:var(--cream);color:var(--orange);transform:translateY(-2px);}
.navcta{font-family:var(--disp);background:var(--orange);color:#fff;font-weight:700;font-size:15px;padding:11px 22px;border-radius:999px;transition:.16s;box-shadow:0 6px 0 #E2603090;flex-shrink:0;}
.navcta:hover{transform:translateY(-2px);box-shadow:0 9px 0 #E2603090;}

.nav-toggle{display:none;flex-direction:column;gap:5px;}
.nav-toggle span{display:block;width:21px;height:2.5px;background:var(--ink);border-radius:2px;transition:.2s;}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* search panel + generic search form */
.search-panel{background:#fff;box-shadow:var(--soft);border-radius:0 0 26px 26px;animation:dropdown .22s ease;}
.search-panel[hidden]{display:none;}
.search-panel>.wrap{padding:18px 28px 22px;}
@keyframes dropdown{from{opacity:0;transform:translateY(-10px);}to{opacity:1;transform:translateY(0);}}
.search-form{display:flex;gap:12px;}
.search-form input[type=search]{flex:1;min-width:0;border:none;border-radius:16px;padding:14px 18px;font-family:var(--sans);font-weight:600;font-size:15px;background:var(--bg);color:var(--ink);}
.search-form input[type=search]:focus{outline:3px solid var(--orange);}

/* ============================================================
   5. BUTTONS
   ============================================================ */
.btn{font-family:var(--disp);font-weight:700;font-size:16px;padding:14px 26px;border-radius:999px;transition:.16s;display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:none;}
.btn-p{background:var(--orange);color:#fff;box-shadow:0 7px 0 #E2603090;}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 10px 0 #E2603090;}
.btn-o{background:#fff;color:var(--ink);box-shadow:0 7px 0 var(--pink);}
.btn-o:hover{transform:translateY(-2px);box-shadow:0 10px 0 var(--pink);}

/* ============================================================
   6. SECTIONS / HEADINGS
   ============================================================ */
.section{padding:80px 0;}
.eyebrow{display:inline-flex;margin-bottom:18px;}
h2.sec{font-family:var(--disp);font-size:clamp(30px,4.6vw,52px);font-weight:800;line-height:1.05;letter-spacing:-.01em;}

/* ============================================================
   7. POST CARD (shared on home / archive / related)
   ============================================================ */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.posts-grid.cols-2{grid-template-columns:repeat(2,1fr);}
.pcard{background:#fff;border-radius:30px;overflow:hidden;transition:.16s;box-shadow:0 10px 26px rgba(58,36,23,.06);display:flex;flex-direction:column;}
.pcard:hover{transform:translateY(-6px);box-shadow:0 20px 36px rgba(255,122,69,.16);}
.pcard .top{aspect-ratio:16/9;position:relative;display:block;overflow:hidden;}
.pcard .top img{width:100%;height:100%;object-fit:cover;}
.pcard .cat{position:absolute;top:14px;left:14px;background:#fff;color:var(--orange);z-index:2;}
.pcard .body{padding:22px 26px 26px;display:flex;flex-direction:column;gap:12px;flex:1;}
.pcard h4{font-family:var(--disp);font-size:21px;font-weight:700;line-height:1.2;}
.pcard h4 a:hover{color:var(--orange);}
.pcard .ex{font-size:14.5px;color:var(--muted);font-weight:600;}
.pcard .meta{font-weight:700;font-size:13px;color:var(--muted);margin-top:auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap;}

/* ============================================================
   8. HOMEPAGE (front-page)
   ============================================================ */
.hero{padding:30px 0;position:relative;}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;}
.hero h1{font-family:var(--disp);font-size:clamp(38px,6vw,72px);font-weight:800;line-height:1.08;letter-spacing:-.02em;text-wrap:balance;}
.hero h1 .hl{color:var(--orange);white-space:nowrap;background:linear-gradient(transparent 62%, var(--yellow) 62%, var(--yellow) 86%, transparent 86%);padding:0 .06em;}
.hero .sub{font-size:18px;font-weight:500;color:#6b5645;margin-top:24px;max-width:42ch;text-wrap:pretty;}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;align-items:center;}
.trust{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14px;color:var(--muted);margin-top:26px;}
.ava{display:flex;}
.ava span{width:34px;height:34px;border-radius:50%;border:3px solid var(--bg);margin-left:-10px;}
.hero-portrait{position:relative;}
.hero-portrait .frame{aspect-ratio:4/4.4;border-radius:42px;overflow:hidden;background:var(--cream);border:6px solid #fff;box-shadow:var(--soft);}
.hero-portrait .frame img{width:100%;height:100%;object-fit:cover;}
.float{position:absolute;background:#fff;border-radius:18px;padding:11px 15px;font-family:var(--disp);font-weight:700;font-size:14px;box-shadow:0 12px 28px rgba(58,36,23,.14);display:flex;align-items:center;gap:8px;}
.float.f1{top:18px;left:-26px;transform:rotate(-6deg);}
.float.f2{bottom:84px;right:-30px;transform:rotate(5deg);}
.float.f3{bottom:-18px;left:30px;transform:rotate(-3deg);background:var(--yellow);}
.blob-bg{position:absolute;border-radius:50%;z-index:-1;filter:blur(2px);opacity:.55;}

/* marquee */
.strip{background:#fff;padding:16px 0;overflow:hidden;border-top:2px dashed var(--pink);border-bottom:2px dashed var(--pink);}
.strip-row{display:flex;gap:34px;white-space:nowrap;font-family:var(--disp);font-weight:700;font-size:17px;color:var(--ink);animation:slide 24s linear infinite;width:max-content;}
.strip-row span{display:inline-flex;align-items:center;gap:34px;}
.strip .dot{color:var(--orange);}
@keyframes slide{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){.strip-row{animation:none;}}

/* stats */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.scard{border-radius:28px;padding:30px 26px;text-align:center;transition:.16s;}
.scard:hover{transform:translateY(-5px);}
.scard:nth-child(1){background:var(--pink);}
.scard:nth-child(2){background:var(--mint);}
.scard:nth-child(3){background:var(--yellow);}
.scard:nth-child(4){background:var(--sky);}
.scard .num{font-family:var(--disp);font-size:clamp(34px,4.4vw,50px);font-weight:800;line-height:1;}
.scard .cap{font-size:14px;font-weight:700;margin-top:10px;color:#5a4536;}

/* about */
.about-card{background:#fff;border-radius:40px;padding:54px;display:grid;grid-template-columns:.8fr 1.2fr;gap:46px;align-items:center;box-shadow:var(--soft);}
.about p{font-size:17px;color:#6b5645;margin-bottom:16px;text-wrap:pretty;}
.about p.big{font-family:var(--disp);font-size:23px;color:var(--ink);font-weight:600;line-height:1.35;}
.about-art{aspect-ratio:1/1;border-radius:32px;background:var(--cream);display:flex;align-items:center;justify-content:center;position:relative;}

/* author E-E-A-T block */
.author-eeat .verify-badge{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);background:var(--mint);color:#19543d;font-family:var(--disp);font-weight:800;font-size:13px;padding:7px 16px;border-radius:999px;white-space:nowrap;box-shadow:0 8px 18px rgba(58,36,23,.12);}
.author-role{font-family:var(--disp);font-weight:700;font-size:15px;color:var(--orange);margin-bottom:16px;}
.author-trust{display:flex;flex-direction:column;gap:9px;margin:18px 0 6px;}
.author-trust span{font-weight:700;font-size:14.5px;color:#5a4536;}
.author-contact{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;}
.author-contact a{display:inline-flex;align-items:center;gap:8px;background:var(--bg);border-radius:999px;padding:10px 18px;font-weight:700;font-size:14px;color:var(--ink);transition:.16s;}
.author-contact a:hover{background:var(--cream);color:var(--orange);transform:translateY(-2px);}
.author-contact .ic{font-size:15px;}

/* skills / categories */
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.scell{background:#fff;border-radius:28px;padding:30px;transition:.16s;box-shadow:0 10px 26px rgba(58,36,23,.06);display:block;}
.scell:hover{transform:translateY(-6px) rotate(-1deg);box-shadow:0 18px 34px rgba(255,122,69,.18);}
.scell .ic{width:60px;height:60px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:18px;}
.scell:nth-child(6n+1) .ic{background:var(--pink);}
.scell:nth-child(6n+2) .ic{background:var(--mint);}
.scell:nth-child(6n+3) .ic{background:var(--yellow);}
.scell:nth-child(6n+4) .ic{background:var(--sky);}
.scell:nth-child(6n+5) .ic{background:var(--coral);}
.scell:nth-child(6n) .ic{background:var(--cream);}
.scell h4{font-family:var(--disp);font-size:20px;font-weight:700;margin-bottom:7px;}
.scell p{font-size:14.5px;color:var(--muted);font-weight:600;}

/* quote */
.quote-card{background:var(--orange);color:#fff;border-radius:40px;padding:60px 54px;text-align:center;position:relative;overflow:hidden;}
.quote-card .q{position:absolute;font-family:var(--disp);font-size:180px;opacity:.18;top:-30px;left:30px;line-height:1;}
.quote-card blockquote{font-family:var(--disp);font-size:clamp(24px,3.4vw,38px);font-weight:700;line-height:1.25;max-width:860px;margin:0 auto 20px;text-wrap:balance;position:relative;border:none;padding:0;}
.quote-card cite{font-style:normal;font-weight:700;font-size:15px;opacity:.92;}

/* section heads on home */
.home-sechead{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:34px;flex-wrap:wrap;}

/* ============================================================
   9. ARCHIVE / SEARCH
   ============================================================ */
.crumb{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px;color:var(--muted);padding:26px 0 6px;flex-wrap:wrap;}
.crumb a:hover{color:var(--orange);}
.crumb .sep{opacity:.5;}
.crumb .cur{color:var(--ink);}

.cathero{padding:18px 0 34px;}
.cathero .kicker{display:inline-flex;background:var(--mint);color:#1f7a5a;margin-bottom:16px;}
.cathero h1{font-family:var(--disp);font-size:clamp(34px,5.4vw,60px);font-weight:800;line-height:1.05;letter-spacing:-.02em;}
.cathero .lead{font-size:18px;font-weight:500;color:#6b5645;max-width:60ch;margin-top:16px;text-wrap:pretty;}
.cathero .facts{display:flex;gap:24px;margin-top:22px;flex-wrap:wrap;}
.cathero .facts b{font-family:var(--disp);font-size:22px;color:var(--orange);}
.cathero .facts span{font-weight:700;font-size:14px;color:var(--muted);}

.filters{display:flex;gap:12px;flex-wrap:wrap;padding:6px 0 30px;border-bottom:2px dashed var(--pink);}
.fchip{font-family:var(--disp);font-weight:700;font-size:15px;padding:10px 20px;border-radius:999px;background:#fff;color:var(--ink);transition:.16s;box-shadow:0 6px 16px rgba(58,36,23,.05);}
.fchip:hover{transform:translateY(-2px);}
.fchip.on{background:var(--orange);color:#fff;box-shadow:0 6px 0 #E2603080;}

.feat{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center;background:#fff;border-radius:36px;padding:18px;box-shadow:var(--soft);margin:34px 0 16px;}
.feat .cover{aspect-ratio:16/11;border-radius:24px;overflow:hidden;display:block;}
.feat .cover img{width:100%;height:100%;object-fit:cover;}
.feat .info{padding:14px 26px 18px 8px;}
.feat .info h2{font-family:var(--disp);font-size:clamp(24px,3vw,36px);font-weight:800;line-height:1.12;letter-spacing:-.01em;margin:14px 0 12px;}
.feat .info h2 a:hover{color:var(--orange);}
.feat .info p{font-size:16px;font-weight:500;color:#6b5645;text-wrap:pretty;}
.feat .row{display:flex;align-items:center;gap:14px;margin-top:20px;flex-wrap:wrap;}
.feat .by{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14px;color:var(--muted);}

.sechead{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:46px 0 22px;flex-wrap:wrap;}
.sechead h3{font-family:var(--disp);font-size:26px;font-weight:800;}
.sechead .sub{font-weight:700;font-size:14px;color:var(--muted);}

/* pagination */
.pager{display:flex;justify-content:center;align-items:center;gap:10px;padding:48px 0 10px;flex-wrap:wrap;}
.pager .page-numbers{font-family:var(--disp);font-weight:700;font-size:16px;min-width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:16px;background:#fff;color:var(--ink);transition:.16s;box-shadow:0 6px 16px rgba(58,36,23,.05);padding:0 14px;}
.pager a.page-numbers:hover{transform:translateY(-2px);color:var(--orange);}
.pager .page-numbers.current{background:var(--orange);color:#fff;}
.pager .page-numbers.dots{box-shadow:none;background:transparent;}

/* newsletter */
.news{background:var(--orange);border-radius:40px;padding:52px;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;color:#fff;position:relative;overflow:hidden;margin:60px 0 10px;}
.news .sun{position:absolute;width:300px;height:300px;border-radius:50%;background:var(--yellow);opacity:.45;right:-80px;top:-90px;}
.news h3{font-family:var(--disp);font-size:clamp(26px,3.4vw,40px);font-weight:800;line-height:1.08;position:relative;}
.news p{font-weight:600;font-size:16px;opacity:.95;margin-top:12px;position:relative;}
.news form{display:flex;gap:12px;position:relative;flex-wrap:wrap;}
.news input{flex:1;min-width:200px;border:none;border-radius:16px;padding:15px 18px;font-family:var(--sans);font-weight:600;font-size:15px;color:var(--ink);}
.news input:focus{outline:3px solid var(--yellow);}

/* ============================================================
   10. SINGLE POST / PAGE
   ============================================================ */
.ahead{max-width:820px;margin:0 auto;padding:14px 0 28px;text-align:center;}
.ahead h1{font-family:var(--disp);font-size:clamp(32px,5vw,56px);font-weight:800;line-height:1.08;letter-spacing:-.02em;margin:16px 0;text-wrap:balance;}
.ahead .lead{font-size:19px;font-weight:500;color:#6b5645;text-wrap:pretty;max-width:62ch;margin:0 auto;}
.ameta{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:24px;font-weight:700;font-size:14px;color:var(--muted);}
.ameta .by{display:flex;align-items:center;gap:9px;color:var(--ink);}
.ameta .dot{width:5px;height:5px;border-radius:50%;background:var(--pink);}

.cover{max-width:1000px;margin:0 auto;aspect-ratio:16/8;border-radius:32px;overflow:hidden;box-shadow:var(--soft);}
.cover img{width:100%;height:100%;object-fit:cover;}

.layout{display:grid;grid-template-columns:1fr 252px;gap:48px;align-items:start;max-width:1000px;margin:46px auto 0;}
.layout.no-toc{grid-template-columns:1fr;max-width:820px;}
.prose{min-width:0;}
.prose>h2,.prose>h3,.prose>h4{font-family:var(--disp);letter-spacing:-.01em;line-height:1.18;scroll-margin-top:96px;}
.prose>h2{font-size:28px;font-weight:800;margin:38px 0 14px;}
.prose>h3{font-size:21px;font-weight:700;margin:26px 0 10px;}
.prose>h4{font-size:18px;font-weight:700;margin:22px 0 8px;}
.prose p{font-size:17.5px;line-height:1.75;color:#4a3528;margin-bottom:18px;text-wrap:pretty;}
.prose ul,.prose ol{margin:0 0 20px 4px;padding-left:24px;}
.prose li{font-size:17.5px;line-height:1.7;color:#4a3528;margin-bottom:10px;}
.prose a{color:var(--orange);font-weight:700;border-bottom:2px solid var(--pink);}
.prose strong{font-weight:800;color:var(--ink);}
.prose img{border-radius:22px;margin:10px 0;}
.prose figure{margin:26px 0;}
.prose figcaption{text-align:center;font-weight:700;font-size:13.5px;color:var(--muted);margin-top:10px;}
.prose blockquote{border:none;background:#fff;border-radius:22px;padding:26px 28px;margin:26px 0;box-shadow:0 8px 20px rgba(58,36,23,.05);}
.prose blockquote p{font-family:var(--disp);font-size:20px;font-weight:600;line-height:1.4;color:var(--ink);margin:0;}
.prose table{width:100%;border-collapse:collapse;margin:24px 0;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 8px 20px rgba(58,36,23,.05);}
.prose th,.prose td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--cream);font-size:15.5px;}
.prose th{background:var(--cream);font-family:var(--disp);}
.prose pre{background:var(--ink);color:#fff;border-radius:18px;padding:20px;overflow:auto;margin:24px 0;font-size:14px;}
.prose code{font-family:"JetBrains Mono",monospace;font-size:.92em;}
.prose :not(pre)>code{background:#fff;padding:2px 7px;border-radius:7px;border:1px solid var(--cream);}
kbd{font-family:"JetBrains Mono",monospace;font-size:13px;font-weight:600;background:#fff;border:2px solid var(--ink);border-radius:8px;padding:2px 9px;box-shadow:0 3px 0 var(--ink);display:inline-block;line-height:1.5;}

.tags2{display:flex;gap:8px;flex-wrap:wrap;margin:34px 0 10px;}
.tag2{font-family:var(--disp);font-weight:700;font-size:13.5px;color:var(--muted);background:#fff;border-radius:999px;padding:7px 16px;box-shadow:0 4px 12px rgba(58,36,23,.05);}
.tag2:hover{color:var(--orange);}

.share{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:24px 0;border-top:2px dashed var(--pink);border-bottom:2px dashed var(--pink);margin:30px 0;}
.share .lb{font-family:var(--disp);font-weight:800;font-size:15px;}
.sbtn{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--disp);font-weight:800;font-size:18px;transition:.16s;cursor:pointer;border:none;}
.sbtn:hover{transform:translateY(-3px) rotate(-3deg);}

.author{display:flex;gap:20px;align-items:center;background:#fff;border-radius:28px;padding:26px 28px;box-shadow:var(--soft);margin:10px 0 0;flex-wrap:wrap;}
.author .av{flex-shrink:0;width:84px;height:84px;border-radius:24px;background:var(--cream);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.author .av img{width:100%;height:100%;object-fit:cover;}
.author h4{font-family:var(--disp);font-size:20px;font-weight:800;}
.author .role{font-weight:700;font-size:13.5px;color:var(--orange);margin-bottom:6px;}
.author p{font-size:14.5px;color:var(--muted);font-weight:600;}
.author .fb{margin-left:auto;}

.toc{position:sticky;top:96px;background:#fff;border-radius:24px;padding:22px;box-shadow:0 10px 26px rgba(58,36,23,.06);}
.toc .tt{font-family:var(--disp);font-weight:800;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;}
.toc ul{list-style:none;display:flex;flex-direction:column;gap:2px;margin:0;padding:0;}
.toc a{display:block;font-weight:700;font-size:14.5px;color:#6b5645;padding:8px 12px;border-radius:12px;transition:.14s;border-left:3px solid transparent;}
.toc a:hover{background:var(--bg);color:var(--orange);}
.toc a.on{background:var(--cream);color:var(--orange);border-left-color:var(--orange);}
.toc .prog{height:6px;border-radius:999px;background:var(--bg);margin-top:14px;overflow:hidden;}
.toc .prog i{display:block;height:100%;width:0;background:var(--orange);transition:width .1s;}

.related{margin:60px 0 0;}
.related h3{font-family:var(--disp);font-size:26px;font-weight:800;margin-bottom:22px;}

/* page (generic) */
.page-body{max-width:820px;margin:0 auto;padding:10px 0 30px;}

/* ============================================================
   11. COMMENTS
   ============================================================ */
.comments-area{max-width:820px;margin:50px auto 0;background:#fff;border-radius:28px;padding:34px;box-shadow:0 10px 26px rgba(58,36,23,.06);}
.comments-area h2,.comments-area h3{font-family:var(--disp);font-weight:800;margin-bottom:18px;}
.comment-list{list-style:none;margin:0;padding:0;}
.comment-list li{margin-bottom:18px;}
.comment-body{background:var(--bg);border-radius:18px;padding:16px 20px;}
.comment-author{font-family:var(--disp);font-weight:700;}
.comment-form input,.comment-form textarea{width:100%;background:var(--bg);border:2px solid transparent;border-radius:16px;padding:14px 16px;font-family:var(--sans);font-weight:600;font-size:15px;color:var(--ink);margin-bottom:12px;}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--orange);background:#fff;}
.comment-form .submit{font-family:var(--disp);background:var(--orange);color:#fff;font-weight:700;font-size:16px;padding:14px 26px;border-radius:999px;border:none;cursor:pointer;box-shadow:0 7px 0 #E2603090;}

/* ============================================================
   12. 404 / NO RESULTS
   ============================================================ */
.error404-wrap{text-align:center;padding:60px 0 80px;max-width:680px;margin:0 auto;}
.error404-wrap .big{font-family:var(--disp);font-size:clamp(80px,16vw,160px);font-weight:800;color:var(--orange);line-height:1;}
.error404-wrap h1{font-family:var(--disp);font-size:clamp(26px,4vw,40px);font-weight:800;margin:14px 0;}
.error404-wrap p{font-size:17px;color:#6b5645;font-weight:500;margin-bottom:26px;}
.error404-wrap .search-form{display:flex;gap:12px;max-width:440px;margin:0 auto;flex-wrap:wrap;}
.error404-wrap input[type=search]{flex:1;min-width:200px;border:none;border-radius:16px;padding:15px 18px;font-family:var(--sans);font-weight:600;font-size:15px;background:#fff;box-shadow:0 8px 22px rgba(58,36,23,.06);}
.error404-wrap input[type=search]:focus{outline:3px solid var(--orange);}

/* ============================================================
   13. FOOTER
   ============================================================ */
.site-footer{padding:64px 0 40px;}
.footer-card{background:#fff;border-radius:40px;padding:52px 54px;box-shadow:var(--soft);}
.footer-cols{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.5fr;gap:42px;}
.footer-brand .brand{margin-bottom:16px;}
.footer-desc{font-size:14.5px;color:var(--muted);font-weight:600;line-height:1.65;max-width:34ch;margin-bottom:18px;}
.footer-social{display:flex;gap:9px;flex-wrap:wrap;}
.fsoc{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--disp);font-weight:800;font-size:16px;transition:.16s;}
.fsoc:hover{transform:translateY(-3px) rotate(-4deg);}
.footer-col h4{font-family:var(--disp);font-size:16px;font-weight:800;margin-bottom:16px;}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.footer-col a{font-weight:700;font-size:14.5px;color:#6b5645;transition:.14s;display:inline-flex;align-items:center;gap:8px;}
.footer-col a:hover{color:var(--orange);}
.footer-col .cnt{font-size:11px;font-weight:800;background:var(--bg);color:var(--muted);border-radius:999px;padding:2px 9px;}
.footer-news-col .footer-desc{margin-bottom:14px;max-width:none;}
.footer-subscribe{display:flex;gap:8px;}
.footer-subscribe input{flex:1;min-width:0;border:none;border-radius:14px;padding:12px 15px;font-family:var(--sans);font-weight:600;font-size:14px;background:var(--bg);color:var(--ink);}
.footer-subscribe input:focus{outline:3px solid var(--orange);}
.footer-subscribe button{flex-shrink:0;width:48px;border:none;border-radius:14px;background:var(--orange);color:#fff;font-size:18px;font-weight:800;cursor:pointer;box-shadow:0 6px 0 #E2603090;transition:.16s;}
.footer-subscribe button:hover{transform:translateY(-2px);box-shadow:0 8px 0 #E2603090;}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;color:var(--muted);font-weight:700;font-size:13.5px;padding:26px 10px 0;}
.foot-bottom strong{color:var(--ink);}
.foot-bottom a:hover{color:var(--orange);}

/* ============================================================
   14. RESPONSIVE
   ============================================================ */
@media(max-width:880px){
  .topbar{display:none;}
  .nav-toggle{display:flex;}
  .navlinks{display:none;position:absolute;top:calc(100% - 4px);left:0;right:0;flex-direction:column;gap:6px;background:#fff;border-radius:24px;padding:14px;box-shadow:var(--soft);z-index:60;}
  .navlinks.open{display:flex;}
  .navlinks>li{position:static;}
  .navlinks a{opacity:1;padding:9px 12px;border-radius:12px;}
  .navlinks .menu-item-has-children>a::after{margin-left:auto;}
  .navlinks .sub-menu{position:static;transform:none;box-shadow:none;padding:2px 0 6px 14px;display:flex;min-width:0;}
  .navlinks .sub-menu::before{display:none;}
  .hero-grid,.about-card,.feat,.contact-card{grid-template-columns:1fr;gap:36px;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .skills-grid,.posts-grid,.posts-grid.cols-2{grid-template-columns:1fr;}
  .layout{grid-template-columns:1fr;}
  .toc{display:none;}
  .section{padding:60px 0;}
  .about-card,.quote-card{padding:34px;border-radius:30px;}
  .news{grid-template-columns:1fr;padding:34px;border-radius:30px;}
  .hero-portrait{max-width:330px;margin:10px auto 0;}
  .float.f1{left:-6px;}.float.f2{right:-8px;}
  .cover{border-radius:24px;}
  /* footer */
  .footer-card{padding:34px;border-radius:30px;}
  .footer-cols{grid-template-columns:1fr 1fr;gap:30px;}
  .footer-brand{grid-column:1 / -1;}
  .foot-bottom{flex-direction:column;text-align:center;gap:8px;}
}
@media(max-width:560px){
  .navcta{display:none;}
  .footer-cols{grid-template-columns:1fr;}
  .brand-name{font-size:19px;}
}
