/*
Theme Name: Project Essay
Theme URI: https://projectessay.com
Author: Project Essay
Author URI: https://projectessay.com
Description: Modern, SEO-optimized WordPress theme for Project Essay — professional essay, research paper, dissertation, and academic assignment help across every academic field. Clean, light editorial design with a fresh teal + coral accent palette, serif display headings, animated call-to-action buttons, rounded cards, related posts, comments disabled, and complete schema.org structured data for Google, Bing, and other search engines.
Version: 1.1.0
Requires at least: 5.9
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: projectessay
Tags: blog, education, light, one-column, custom-colors, featured-images
*/

/* ==========================================================================
   1. Design Tokens — Clean, Modern, Light
   ========================================================================== */
:root{
  /* Backgrounds — soft, airy, off-white with a hint of mint */
  --pe-bg:#f7fbfa;             /* page background — barely-tinted mint white */
  --pe-surface:#ffffff;        /* cards, header, hero */
  --pe-soft:#eaf5f2;           /* pale mint for subtle fills / chips */
  --pe-soft-2:#fff3ef;         /* warm coral tint for secondary highlights */

  /* Text — deep slate, not pure black. High contrast, easy on the eyes. */
  --pe-text:#0f2a33;           /* deep teal-slate for body text */
  --pe-muted:#5c7079;          /* muted slate for secondary text */
  --pe-border:#dde8e6;         /* soft mint-gray borders */

  /* Accents — Teal primary, Coral secondary. Fresh & professional. */
  --pe-accent:#0f9d8b;         /* teal — primary CTA / links */
  --pe-accent-hover:#0b7f70;   /* deeper teal for hover */
  --pe-accent-text:#ffffff;    /* text on accent buttons */
  --pe-accent-2:#ff6b57;       /* coral — used sparingly for highlights */
  --pe-accent-2-hover:#e8523d; /* deeper coral for hover */

  /* Structure */
  --pe-radius:14px;
  --pe-radius-lg:20px;
  --pe-shadow:0 1px 3px rgba(15,42,51,.06);
  --pe-shadow-md:0 6px 20px rgba(15,42,51,.08);
  --pe-shadow-lg:0 12px 40px rgba(15,42,51,.10);
  --pe-max:1160px;
  --pe-content:760px;
  --pe-font-head:'Fraunces',Georgia,'Times New Roman',serif;
  --pe-font-body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
}

/* ==========================================================================
   2. Base
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  margin:0;background:var(--pe-bg);color:var(--pe-text);
  font-family:var(--pe-font-body);font-size:1.0625rem;line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4,h5,h6{
  font-family:var(--pe-font-head);font-weight:700;line-height:1.2;
  margin:0 0 .6em;color:var(--pe-text);letter-spacing:-.01em;
}
h1{font-size:clamp(2rem,4.2vw,2.9rem)}
h2{font-size:clamp(1.55rem,3vw,2.1rem)}
h3{font-size:1.25rem}
p{margin:0 0 1.2em}
a{color:var(--pe-accent);text-decoration:none;transition:color .18s ease}
a:hover{color:var(--pe-accent-hover)}
a:focus-visible,button:focus-visible,input:focus-visible{
  outline:3px solid var(--pe-accent);outline-offset:2px;border-radius:4px;
}
.screen-reader-text{
  clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;
  overflow:hidden;position:absolute!important;word-wrap:normal!important;
}
.pe-container{max-width:var(--pe-max);margin:0 auto;padding:0 20px}

/* ==========================================================================
   3. Buttons — Customizer-controlled colors, gentle lift on hover
   ========================================================================== */
.pe-btn,
.wp-block-button__link,
button[type=submit],
input[type=submit]{
  display:inline-block;background:var(--pe-accent);color:var(--pe-accent-text);
  font-family:var(--pe-font-body);font-weight:600;font-size:.98rem;letter-spacing:.01em;
  padding:.85rem 1.7rem;border:0;border-radius:10px;cursor:pointer;
  text-decoration:none;transition:background .18s ease,transform .18s ease,box-shadow .18s ease;
  box-shadow:0 2px 8px rgba(15,157,139,.20);
}
.pe-btn:hover,
.wp-block-button__link:hover,
button[type=submit]:hover,
input[type=submit]:hover{
  background:var(--pe-accent-hover);color:var(--pe-accent-text);
  transform:translateY(-2px);box-shadow:0 8px 22px rgba(15,157,139,.28);
}
.pe-btn--ghost{
  background:transparent;color:var(--pe-text);box-shadow:inset 0 0 0 1.5px var(--pe-border);
}
.pe-btn--ghost:hover{background:#fff;color:var(--pe-accent);box-shadow:inset 0 0 0 1.5px var(--pe-accent)}
.pe-btn--lg{padding:1rem 2.1rem;font-size:1.05rem}
.pe-btn--coral{background:var(--pe-accent-2);box-shadow:0 2px 8px rgba(255,107,87,.25)}
.pe-btn--coral:hover{background:var(--pe-accent-2-hover);box-shadow:0 8px 22px rgba(255,107,87,.32)}

/* Attention pulse on primary buttons. Disabled for prefers-reduced-motion. */
@keyframes pe-pulse{
  0%,100%{box-shadow:0 0 0 0 var(--pe-pulse,color-mix(in srgb,var(--pe-accent) 45%,transparent)), 0 2px 8px rgba(15,157,139,.20)}
  55%{box-shadow:0 0 0 12px transparent, 0 2px 8px rgba(15,157,139,.20)}
}
.pe-btn--pulse{animation:pe-pulse 1.9s ease-out infinite}

/* ==========================================================================
   4. Header
   ========================================================================== */
.pe-header{
  background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(10px);
  -webkit-backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--pe-border);
  position:sticky;top:0;z-index:50;
}
.pe-header__inner{display:flex;align-items:center;gap:24px;min-height:72px}
.pe-logo{display:flex;align-items:center;gap:10px;font-family:var(--pe-font-head);font-weight:800;font-size:1.35rem;color:var(--pe-text)}
.pe-logo:hover{color:var(--pe-text)}
.pe-logo__mark{width:38px;height:38px;display:block}
.pe-logo__text{letter-spacing:-.02em}
.pe-logo__accent{color:var(--pe-accent)}
.pe-logo img{max-height:44px;width:auto}
.pe-nav{margin-left:auto}
.pe-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:6px;align-items:center}
.pe-nav a{
  display:block;padding:.55rem .9rem;border-radius:8px;
  color:var(--pe-text);font-weight:500;font-size:.95rem;
}
.pe-nav a:hover{background:var(--pe-soft);color:var(--pe-accent)}
.pe-nav .current-menu-item > a{color:var(--pe-accent);font-weight:600}
.pe-header__cta{white-space:nowrap}
.pe-nav-toggle{
  display:none;margin-left:auto;background:none;border:1.5px solid var(--pe-border);
  border-radius:8px;padding:.5rem .7rem;font-size:1.1rem;line-height:1;cursor:pointer;color:var(--pe-text);
}
@media (max-width:860px){
  .pe-nav-toggle{display:block}
  .pe-header__cta{display:none}
  .pe-nav{
    display:none;position:absolute;left:0;right:0;top:100%;
    background:var(--pe-surface);border-bottom:1px solid var(--pe-border);
    padding:10px 20px 16px;margin:0;box-shadow:var(--pe-shadow-md);
  }
  .pe-nav.is-open{display:block}
  .pe-nav ul{flex-direction:column;align-items:stretch;gap:2px}
}

/* ==========================================================================
   5. Hero (front page) — light gradient background
   ========================================================================== */
.pe-hero{
  background:
    radial-gradient(1200px 500px at 85% -10%,rgba(15,157,139,.10),transparent 60%),
    radial-gradient(900px 400px at 0% 100%,rgba(255,107,87,.08),transparent 55%),
    var(--pe-surface);
  border-bottom:1px solid var(--pe-border);
  padding:84px 0 76px;
}
.pe-hero__inner{max-width:860px}
.pe-hero__eyebrow{
  display:inline-block;font-family:var(--pe-font-body);font-size:.8rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--pe-accent);
  background:color-mix(in srgb,var(--pe-accent) 12%,#fff);
  border:1px solid color-mix(in srgb,var(--pe-accent) 30%,#fff);
  padding:.35rem .85rem;border-radius:999px;margin-bottom:20px;
}
.pe-hero h1{margin-bottom:.4em;letter-spacing:-.015em}
.pe-hero h1 .pe-hi{color:var(--pe-accent);position:relative;white-space:nowrap}
.pe-hero h1 .pe-hi::after{
  content:"";position:absolute;left:0;right:0;bottom:.04em;height:.28em;
  background:color-mix(in srgb,var(--pe-accent-2) 45%,transparent);
  z-index:-1;border-radius:6px;
}
.pe-hero__sub{font-size:1.18rem;color:var(--pe-muted);max-width:680px}
.pe-hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.pe-hero__points{
  display:flex;gap:22px;flex-wrap:wrap;margin-top:30px;padding:0;list-style:none;
  color:var(--pe-muted);font-size:.92rem;
}
.pe-hero__points li::before{content:"✓";color:var(--pe-accent);font-weight:700;margin-right:7px}

/* Deliverable chips (hero) */
.pe-chips{display:flex;flex-wrap:wrap;gap:10px;list-style:none;margin:32px 0 0;padding:0}
.pe-chips li{
  background:var(--pe-surface);color:var(--pe-text);
  border:1px solid var(--pe-border);border-radius:999px;
  padding:.45rem 1.05rem;font-family:var(--pe-font-body);font-weight:600;font-size:.88rem;
  box-shadow:var(--pe-shadow);
  transition:transform .18s ease,border-color .18s ease;
}
.pe-chips li:hover{transform:translateY(-2px);border-color:var(--pe-accent)}
.pe-chips li::before{
  content:"";display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--pe-accent);margin-right:8px;vertical-align:middle;
}
.pe-write-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}

/* Trust bar (below hero chips) */
.pe-trust{
  display:flex;flex-wrap:wrap;gap:26px;margin-top:34px;padding:0;list-style:none;
  color:var(--pe-muted);font-size:.9rem;align-items:center;
}
.pe-trust li{display:flex;align-items:center;gap:8px}
.pe-trust strong{color:var(--pe-text);font-weight:700;font-family:var(--pe-font-head)}
.pe-trust .pe-stars{color:var(--pe-accent-2);letter-spacing:2px;font-size:1rem}

/* Stats strip */
.pe-stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:14px;margin:34px 0 0;padding:0;
}
.pe-stats__item{
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);padding:16px 18px;
}
.pe-stats__item dt{font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;color:var(--pe-muted);margin:0 0 4px}
.pe-stats__item dd{font-family:var(--pe-font-head);font-weight:800;font-size:1.15rem;margin:0;color:var(--pe-accent)}

/* Why split section */
.pe-why{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
@media (max-width:860px){.pe-why{grid-template-columns:1fr}}
.pe-why__text p{color:var(--pe-muted);margin-bottom:22px}
.pe-why__list{list-style:none;margin:0;padding:0}
.pe-why__list li{
  position:relative;padding:.7em 0 .7em 34px;
  border-bottom:1px dashed var(--pe-border);font-size:.97rem;
}
.pe-why__list li:last-child{border-bottom:0}
.pe-why__list li::before{
  content:"✓";position:absolute;left:0;top:.62em;
  width:22px;height:22px;border-radius:50%;
  background:var(--pe-soft);color:var(--pe-accent);
  font-weight:700;font-size:.75rem;display:grid;place-items:center;
}

/* Hero search */
.pe-hero__search{margin-top:28px;max-width:560px}
.pe-hero__search input[type=search]{font-size:1.02rem}
.pe-hero__actions{margin-top:20px}

/* FAQ */
.pe-faq{max-width:820px}
.pe-faq__item{
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);padding:0;margin-bottom:12px;overflow:hidden;
  transition:box-shadow .18s ease;
}
.pe-faq__item:hover{box-shadow:var(--pe-shadow)}
.pe-faq__item summary{
  cursor:pointer;list-style:none;padding:18px 22px;
  font-family:var(--pe-font-head);font-weight:600;font-size:1.05rem;
  position:relative;padding-right:52px;color:var(--pe-text);
}
.pe-faq__item summary::-webkit-details-marker{display:none}
.pe-faq__item summary::after{
  content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  background:var(--pe-soft);color:var(--pe-accent);font-weight:700;
  transition:transform .2s ease,background .2s ease;
}
.pe-faq__item[open] summary::after{content:"–";background:var(--pe-accent);color:#fff}
.pe-faq__item[open] summary{border-bottom:1px solid var(--pe-border)}
.pe-faq__item p{margin:0;padding:16px 22px 20px;color:var(--pe-muted);font-size:.97rem}

/* ==========================================================================
   6. Sections & subject grid
   ========================================================================== */
.pe-section{padding:70px 0}
.pe-section--alt{background:linear-gradient(180deg,var(--pe-bg) 0%,var(--pe-soft) 100%)}
.pe-section__head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:34px;flex-wrap:wrap}
.pe-section__head h2{margin-bottom:.2em}
.pe-section__head p{color:var(--pe-muted);margin:0;font-size:1.02rem}
.pe-section__eyebrow{
  display:inline-block;font-family:var(--pe-font-body);font-size:.78rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--pe-accent);margin-bottom:10px;
}

/* Subjects — clean modern cards */
.pe-subjects{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;padding:0;margin:0;list-style:none}
.pe-subjects a{
  display:flex;align-items:center;gap:10px;
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);padding:14px 16px;color:var(--pe-text);
  font-family:var(--pe-font-body);font-weight:600;font-size:.94rem;
  transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease;
}
.pe-subjects a::before{
  content:"";flex-shrink:0;width:8px;height:8px;border-radius:50%;
  background:var(--pe-accent);opacity:.55;transition:opacity .18s ease,transform .18s ease;
}
.pe-subjects a:hover{border-color:var(--pe-accent);transform:translateY(-3px);box-shadow:var(--pe-shadow-md);color:var(--pe-accent)}
.pe-subjects a:hover::before{opacity:1;transform:scale(1.4)}

/* Steps — modern numbered cards */
.pe-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.pe-step{
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);padding:28px 26px;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.pe-step:hover{transform:translateY(-4px);box-shadow:var(--pe-shadow-md);border-color:color-mix(in srgb,var(--pe-accent) 40%,var(--pe-border))}
.pe-step__num{
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:var(--pe-accent);color:var(--pe-accent-text);
  font-family:var(--pe-font-head);font-weight:700;margin-bottom:16px;font-size:1rem;
  box-shadow:0 4px 12px rgba(15,157,139,.28);
}
.pe-step h3{font-size:1.18rem;margin-bottom:.4em}
.pe-step p{color:var(--pe-muted);font-size:.95rem;margin:0}

/* Feature grid — icons + text (used on new "Why choose us" section) */
.pe-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.pe-feature{
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);padding:26px 24px;
  transition:transform .2s ease,box-shadow .2s ease;
}
.pe-feature:hover{transform:translateY(-3px);box-shadow:var(--pe-shadow-md)}
.pe-feature__icon{
  width:48px;height:48px;border-radius:12px;display:grid;place-items:center;
  background:var(--pe-soft);color:var(--pe-accent);font-size:1.4rem;margin-bottom:16px;
}
.pe-feature:nth-child(2n) .pe-feature__icon{background:var(--pe-soft-2);color:var(--pe-accent-2)}
.pe-feature h3{font-size:1.1rem;margin-bottom:.4em}
.pe-feature p{color:var(--pe-muted);font-size:.94rem;margin:0}

/* CTA band */
.pe-cta-band{
  background:linear-gradient(135deg,var(--pe-accent) 0%,#0b7f70 100%);
  border-radius:var(--pe-radius-lg);padding:56px 44px;
  display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;
  box-shadow:0 20px 50px rgba(15,157,139,.25);
  position:relative;overflow:hidden;
}
.pe-cta-band::before{
  content:"";position:absolute;top:-40%;right:-10%;width:400px;height:400px;
  background:radial-gradient(circle,rgba(255,107,87,.25),transparent 65%);
  pointer-events:none;
}
.pe-cta-band h2{color:#fff;margin:0 0 .3em;font-size:clamp(1.6rem,2.6vw,2rem)}
.pe-cta-band p{color:rgba(255,255,255,.9);margin:0;font-size:1.02rem;max-width:520px}
.pe-cta-band .pe-btn{background:#fff;color:var(--pe-accent);box-shadow:0 6px 20px rgba(0,0,0,.15);position:relative;z-index:1}
.pe-cta-band .pe-btn:hover{background:var(--pe-soft);color:var(--pe-accent-hover)}
.pe-cta-band .pe-btn--pulse{--pe-pulse:rgba(255,255,255,.55)}

/* Testimonial cards */
.pe-testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.pe-testimonial{
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);padding:26px 24px;
  transition:transform .2s ease,box-shadow .2s ease;
}
.pe-testimonial:hover{transform:translateY(-3px);box-shadow:var(--pe-shadow-md)}
.pe-testimonial__stars{color:var(--pe-accent-2);letter-spacing:2px;font-size:1rem;margin-bottom:12px}
.pe-testimonial__text{color:var(--pe-text);font-size:.98rem;margin:0 0 16px;font-style:italic}
.pe-testimonial__author{color:var(--pe-muted);font-size:.88rem;font-weight:600}
.pe-testimonial__author strong{color:var(--pe-text);display:block;font-family:var(--pe-font-head)}

/* ==========================================================================
   7. Post cards / archives
   ========================================================================== */
.pe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.pe-card{
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);overflow:hidden;display:flex;flex-direction:column;
  transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease;
}
.pe-card:hover{box-shadow:var(--pe-shadow-md);transform:translateY(-3px);border-color:color-mix(in srgb,var(--pe-accent) 30%,var(--pe-border))}
.pe-card__thumb{aspect-ratio:16/9;background:var(--pe-soft)}
.pe-card__thumb img{width:100%;height:100%;object-fit:cover}
.pe-card__body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.pe-card__cat{
  font-family:var(--pe-font-body);font-size:.72rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--pe-accent);margin-bottom:8px;
}
.pe-card__title{font-size:1.15rem;margin-bottom:.45em}
.pe-card__title a{color:var(--pe-text)}
.pe-card__title a:hover{color:var(--pe-accent)}
.pe-card__excerpt{color:var(--pe-muted);font-size:.93rem;margin:0 0 14px}
.pe-card__meta{margin-top:auto;color:var(--pe-muted);font-size:.82rem}
.pe-archive-head{padding:56px 0 8px}
.pe-archive-head h1{margin-bottom:.2em}
.pe-archive-head p{color:var(--pe-muted);max-width:640px}

/* Pagination */
.pe-pagination{margin:40px 0 10px;text-align:center}
.pe-pagination .nav-links{display:inline-flex;gap:6px;flex-wrap:wrap;justify-content:center}
.pe-pagination .page-numbers{
  display:inline-block;min-width:42px;padding:.55rem .8rem;border-radius:8px;
  background:var(--pe-surface);border:1px solid var(--pe-border);
  color:var(--pe-text);font-weight:600;font-size:.92rem;
}
.pe-pagination .page-numbers:hover{border-color:var(--pe-accent);color:var(--pe-accent)}
.pe-pagination .page-numbers.current{background:var(--pe-accent);border-color:var(--pe-accent);color:var(--pe-accent-text)}
.pe-pagination .page-numbers.dots{border:0;background:none}

/* ==========================================================================
   8. Single post
   ========================================================================== */
.pe-breadcrumbs{font-size:.85rem;color:var(--pe-muted);padding:22px 0 0}
.pe-breadcrumbs a{color:var(--pe-muted)}
.pe-breadcrumbs a:hover{color:var(--pe-accent)}
.pe-breadcrumbs .sep{margin:0 .5em;opacity:.5}
.pe-single-layout{
  display:grid;grid-template-columns:minmax(0,1fr) 320px;
  gap:34px;align-items:start;padding-top:26px;padding-bottom:60px;
}
.pe-single{max-width:var(--pe-content);min-width:0;margin:0;padding:0}
@media (max-width:960px){
  .pe-single-layout{grid-template-columns:1fr}
  .pe-single{max-width:none}
}

/* Sidebar */
.pe-sidebar{position:sticky;top:92px;display:flex;flex-direction:column;gap:20px}
@media (max-width:960px){.pe-sidebar{position:static}}
.pe-widget{
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);padding:24px 24px 26px;
}
.pe-widget__title{
  font-size:1.02rem;margin:0 0 16px;padding-bottom:12px;
  border-bottom:2px solid var(--pe-accent);
}
.pe-widget ul{list-style:none;margin:0;padding:0}
.pe-widget li{margin-bottom:.6em;font-size:.92rem}
.pe-widget a{color:var(--pe-text)}
.pe-widget a:hover{color:var(--pe-accent)}

/* Free features box */
.pe-features{border-top:4px solid var(--pe-accent)}
.pe-features__list{list-style:none;margin:0 0 20px;padding:0}
.pe-features__list li{
  position:relative;padding:.5em 0 .5em 30px;font-size:.92rem;
  color:var(--pe-text);border-bottom:1px dashed var(--pe-border);
}
.pe-features__list li:last-child{border-bottom:0}
.pe-features__list li::before{
  content:"✓";position:absolute;left:0;top:.42em;
  width:20px;height:20px;border-radius:50%;
  background:color-mix(in srgb,var(--pe-accent) 14%,#fff);
  color:var(--pe-accent);font-weight:700;font-size:.72rem;
  display:grid;place-items:center;
}
.pe-features__btn{display:block;text-align:center;width:100%}
.pe-single__header{margin-bottom:26px}
.pe-single__cat{display:inline-block;margin-bottom:12px}
.pe-single__meta{color:var(--pe-muted);font-size:.9rem;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.pe-single__thumb{border-radius:var(--pe-radius);overflow:hidden;margin:26px 0}
.pe-entry{
  background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:var(--pe-radius);padding:clamp(24px,4vw,44px);
}
.pe-entry > *:first-child{margin-top:0}
.pe-entry h2{margin-top:1.6em}
.pe-entry h3{margin-top:1.4em}
.pe-entry ul,.pe-entry ol{padding-left:1.4em;margin:0 0 1.2em}
.pe-entry li{margin-bottom:.4em}
.pe-entry blockquote{
  margin:1.4em 0;padding:.8em 1.2em;border-left:4px solid var(--pe-accent);
  background:var(--pe-soft);border-radius:0 8px 8px 0;color:var(--pe-muted);
}
.pe-entry table{width:100%;border-collapse:collapse;margin:1.4em 0;font-size:.95rem}
.pe-entry th,.pe-entry td{border:1px solid var(--pe-border);padding:.6em .8em;text-align:left}
.pe-entry th{background:var(--pe-soft);font-family:var(--pe-font-head);font-size:.85rem}
.pe-entry img{border-radius:8px}
.pe-entry code{background:var(--pe-soft);padding:.15em .4em;border-radius:5px;font-size:.9em}
.pe-entry pre{background:#0f2a33;color:#e8eaf0;padding:1.1em 1.3em;border-radius:8px;overflow:auto;font-size:.88rem}
.pe-entry pre code{background:none;padding:0;color:inherit}
.pe-tags{margin-top:22px;display:flex;gap:8px;flex-wrap:wrap}
.pe-tags a{
  font-size:.8rem;background:var(--pe-surface);border:1px solid var(--pe-border);
  border-radius:999px;padding:.3rem .8rem;color:var(--pe-muted);
}
.pe-tags a:hover{border-color:var(--pe-accent);color:var(--pe-accent)}
.pe-post-cta{
  margin-top:30px;background:var(--pe-surface);border:1px solid var(--pe-border);
  border-left:4px solid var(--pe-accent);border-radius:var(--pe-radius);
  padding:24px 26px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
}
.pe-post-cta strong{font-family:var(--pe-font-head);font-size:1.05rem}
.pe-post-cta p{margin:0;color:var(--pe-muted);font-size:.92rem}

/* Related posts */
.pe-related{padding:10px 0 70px}
.pe-related h2{font-size:1.4rem;margin-bottom:20px}

/* ==========================================================================
   9. Footer
   ========================================================================== */
.pe-footer{background:var(--pe-surface);border-top:1px solid var(--pe-border);margin-top:20px}
.pe-footer__grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;padding:56px 0 40px;
}
.pe-footer h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--pe-muted);margin-bottom:14px;font-family:var(--pe-font-body);font-weight:700}
.pe-footer ul{list-style:none;margin:0;padding:0}
.pe-footer li{margin-bottom:.55em}
.pe-footer a{color:var(--pe-text);font-size:.93rem}
.pe-footer a:hover{color:var(--pe-accent)}
.pe-footer__about{color:var(--pe-muted);font-size:.93rem;max-width:320px}
.pe-footer__bar{
  border-top:1px solid var(--pe-border);padding:20px 0;
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  color:var(--pe-muted);font-size:.85rem;
}
@media (max-width:860px){.pe-footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.pe-footer__grid{grid-template-columns:1fr}}

/* ==========================================================================
   10. Misc (page, search, 404, forms)
   ========================================================================== */
.pe-page{max-width:var(--pe-content);margin:0 auto;padding:48px 20px 70px}
.pe-search-form{display:flex;gap:10px;max-width:480px}
.pe-search-form input[type=search]{
  flex:1;padding:.85rem 1rem;border:1.5px solid var(--pe-border);
  border-radius:10px;font-size:1rem;background:#fff;color:var(--pe-text);
}
.pe-search-form input[type=search]:focus{border-color:var(--pe-accent);outline:none;box-shadow:0 0 0 4px color-mix(in srgb,var(--pe-accent) 15%,transparent)}
.pe-404{text-align:center;padding:90px 20px}
.pe-404 .pe-404__code{font-family:var(--pe-font-head);font-size:5rem;font-weight:800;color:var(--pe-accent);line-height:1}
.alignwide{max-width:calc(var(--pe-content) + 160px);margin-left:auto;margin-right:auto}
.alignfull{width:100%;max-width:100%}
