/*
Theme Name: Project Essay
Theme URI: https://projectessay.com
Author: Project Essay
Author URI: https://projectessay.com
Description: Lightweight, SEO-optimized WordPress theme for Project Essay — professional essay, research paper, and academic project writing help across all fields. Editorial light design with violet pulse-animated call-to-action buttons (customizable), serif display headings, rounded cards, related posts, comments disabled, and full schema.org structured data for Google, Bing, and other search engines.
Version: 1.0.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. Tokens
   ========================================================================== */
:root{
  --pe-bg:#fdfcff;           /* lavender-tinted white */
  --pe-surface:#ffffff;
  --pe-soft:#f4f0fb;         /* pale lavender for subtle fills */
  --pe-text:#231a35;         /* deep plum text */
  --pe-muted:#665d7e;
  --pe-border:#e8e3f2;       /* soft lavender-gray borders */
  --pe-accent:#7c3aed;       /* violet — overridden by Customizer */
  --pe-accent-hover:#6a2bd9; /* overridden by Customizer */
  --pe-accent-text:#ffffff;  /* overridden by Customizer */
  --pe-radius:14px;
  --pe-shadow:0 1px 3px rgba(35,26,53,.06);
  --pe-max:1160px;
  --pe-content:760px;
  --pe-font-head:'Fraunces',Georgia,'Times New Roman',serif;
  --pe-font-body: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.25;
  margin:0 0 .6em;color:var(--pe-text);letter-spacing:-.005em;
}
h1{font-size:clamp(1.9rem,4vw,2.6rem)}
h2{font-size:clamp(1.5rem,3vw,1.9rem)}
h3{font-size:1.25rem}
p{margin:0 0 1.2em}
a{color:var(--pe-accent);text-decoration:none}
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)
   ========================================================================== */
.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-head);font-weight:600;font-size:.95rem;
  padding:.75rem 1.5rem;border:0;border-radius:8px;cursor:pointer;
  text-decoration:none;transition:background .18s ease,transform .18s ease;
}
.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(-1px);
}
.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-text);box-shadow:inset 0 0 0 1.5px var(--pe-accent)}
.pe-btn--lg{padding:.95rem 2rem;font-size:1.05rem}

/* Attention pulse on primary buttons ("blinking"). Disabled automatically
   for visitors with prefers-reduced-motion via the rule in section 2. */
@keyframes pe-pulse{
  0%,100%{box-shadow:0 0 0 0 var(--pe-pulse,color-mix(in srgb,var(--pe-accent) 45%,transparent))}
  55%{box-shadow:0 0 0 11px transparent}
}
.pe-btn--pulse{animation:pe-pulse 1.8s ease-out infinite}


/* ==========================================================================
   4. Header
   ========================================================================== */
.pe-header{
  background:var(--pe-surface);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:70px}
.pe-logo{display:flex;align-items:center;gap:10px;font-family:var(--pe-font-head);font-weight:800;font-size:1.3rem;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:42px;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 .85rem;border-radius:8px;
  color:var(--pe-text);font-weight:500;font-size:.95rem;
}
.pe-nav a:hover{background:var(--pe-soft);color:var(--pe-text)}
.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);
  }
  .pe-nav.is-open{display:block}
  .pe-nav ul{flex-direction:column;align-items:stretch;gap:2px}
}

/* ==========================================================================
   5. Hero (front page)
   ========================================================================== */
.pe-hero{background:var(--pe-surface);border-bottom:1px solid var(--pe-border);padding:72px 0 64px}
.pe-hero__inner{max-width:820px}
.pe-hero__eyebrow{
  display:inline-block;font-family:var(--pe-font-head);font-size:.8rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--pe-accent);
  background:color-mix(in srgb,var(--pe-accent) 10%,#fff);
  border:1px solid color-mix(in srgb,var(--pe-accent) 25%,#fff);
  padding:.3rem .75rem;border-radius:999px;margin-bottom:18px;
}
.pe-hero h1{margin-bottom:.5em}
.pe-hero__sub{font-size:1.15rem;color:var(--pe-muted);max-width:640px}
.pe-hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.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:30px 0 0;padding:0}
.pe-chips li{
  background:var(--pe-soft);color:var(--pe-accent);
  border:1px solid var(--pe-border);border-radius:999px;
  padding:.4rem 1rem;font-family:var(--pe-font-head);font-weight:600;font-size:.88rem;
}
.pe-write-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}

/* 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:16px}

/* 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;
}
.pe-faq__item summary{
  cursor:pointer;list-style:none;padding:18px 22px;
  font-family:var(--pe-font-head);font-weight:600;font-size:1.02rem;
  position:relative;padding-right:52px;
}
.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:26px;height:26px;border-radius:50%;display:grid;place-items:center;
  background:var(--pe-soft);color:var(--pe-accent);font-weight:700;
}
.pe-faq__item[open] summary::after{content:"–"}
.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:.96rem}

/* ==========================================================================
   6. Sections & subject grid
   ========================================================================== */
.pe-section{padding:60px 0}
.pe-section__head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.pe-section__head p{color:var(--pe-muted);margin:0}
.pe-subjects{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;padding:0;margin:0;list-style:none}
.pe-subjects a{
  display:block;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-head);font-weight:600;font-size:.92rem;
  transition:border-color .18s ease,transform .18s ease;
}
.pe-subjects a:hover{border-color:var(--pe-accent);transform:translateY(-2px)}
.pe-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px}
.pe-step{background:var(--pe-surface);border:1px solid var(--pe-border);border-radius:var(--pe-radius);padding:24px}
.pe-step__num{
  width:34px;height:34px;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:14px;font-size:.95rem;
}
.pe-step p{color:var(--pe-muted);font-size:.95rem;margin:0}
.pe-cta-band{
  background:var(--pe-accent);border-radius:20px;padding:48px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.pe-cta-band h2{color:#fff;margin:0 0 .25em}
.pe-cta-band p{color:rgba(255,255,255,.85);margin:0}
.pe-cta-band .pe-btn{background:#fff;color:var(--pe-accent)}
.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)}

/* ==========================================================================
   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;
}
.pe-card:hover{box-shadow:var(--pe-shadow);transform:translateY(-3px)}
.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-head);font-size:.72rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--pe-accent);margin-bottom:8px;
}
.pe-card__title{font-size:1.12rem;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:48px 0 8px}
.pe-archive-head h1{margin-bottom:.2em}
.pe-archive-head p{color:var(--pe-muted);max-width:640px}

/* Pagination — plain crawlable links */
.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:#14171c;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:52px 0 36px;
}
.pe-footer h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--pe-muted);margin-bottom:14px}
.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:18px 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:.75rem 1rem;border:1.5px solid var(--pe-border);
  border-radius:8px;font-size:1rem;background:#fff;color:var(--pe-text);
}
.pe-search-form input[type=search]:focus{border-color:var(--pe-accent);outline:none}
.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%}
