/*
Theme Name: InterEssay
Theme URI: https://interessay.com
Author: InterEssay
Author URI: https://interessay.com
Description: Lightweight, SEO-optimized WordPress theme for InterEssay — professional academic writing, editing, and research support to international standards, across all disciplines. Clean crimson-and-white design with customizable call-to-action buttons, injected SEO title, description, and keyword meta tags, related posts, comments disabled, and full schema.org structured data.
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: interessay
Tags: blog, education, light, one-column, custom-colors, featured-images
*/

/* ==========================================================================
   1. Tokens
   ========================================================================== */
:root{
  --ie-bg:#fcfcfd;           /* cool white */
  --ie-surface:#ffffff;
  --ie-soft:#faf2f4;         /* pale rose for subtle fills */
  --ie-text:#1d1b22;         /* ink text */
  --ie-muted:#6a6572;
  --ie-border:#eae7ee;       /* soft cool-gray borders */
  --ie-accent:#be123c;       /* academic crimson — overridden by Customizer */
  --ie-accent-hover:#9f1239; /* overridden by Customizer */
  --ie-accent-text:#ffffff;  /* overridden by Customizer */
  --ie-radius:12px;
  --ie-shadow:0 1px 3px rgba(29,27,34,.06);
  --ie-max:1160px;
  --ie-content:760px;
  --ie-font-head:'Albert Sans',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  --ie-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(--ie-bg);color:var(--ie-text);
  font-family:var(--ie-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(--ie-font-head);font-weight:700;line-height:1.25;
  margin:0 0 .6em;color:var(--ie-text);letter-spacing:-.015em;
}
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(--ie-accent);text-decoration:none}
a:hover{color:var(--ie-accent-hover)}
a:focus-visible,button:focus-visible,input:focus-visible{
  outline:3px solid var(--ie-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;
}
.ie-container{max-width:var(--ie-max);margin:0 auto;padding:0 20px}

/* ==========================================================================
   3. Buttons (Customizer-controlled colors)
   ========================================================================== */
.ie-btn,
.wp-block-button__link,
button[type=submit],
input[type=submit]{
  display:inline-block;background:var(--ie-accent);color:var(--ie-accent-text);
  font-family:var(--ie-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;
}
.ie-btn:hover,
.wp-block-button__link:hover,
button[type=submit]:hover,
input[type=submit]:hover{
  background:var(--ie-accent-hover);color:var(--ie-accent-text);transform:translateY(-1px);
}
.ie-btn--ghost{
  background:transparent;color:var(--ie-text);
  box-shadow:inset 0 0 0 1.5px var(--ie-border);
}
.ie-btn--ghost:hover{background:#fff;color:var(--ie-text);box-shadow:inset 0 0 0 1.5px var(--ie-accent)}
.ie-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 ie-pulse{
  0%,100%{box-shadow:0 0 0 0 var(--ie-pulse,color-mix(in srgb,var(--ie-accent) 45%,transparent))}
  55%{box-shadow:0 0 0 11px transparent}
}
.ie-btn--pulse{animation:ie-pulse 1.8s ease-out infinite}


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

/* ==========================================================================
   5. Hero (front page)
   ========================================================================== */
.ie-hero{background:var(--ie-surface);border-bottom:1px solid var(--ie-border);padding:72px 0 64px}
.ie-hero__inner{max-width:820px}
.ie-hero__eyebrow{
  display:inline-block;font-family:var(--ie-font-head);font-size:.8rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ie-accent);
  background:color-mix(in srgb,var(--ie-accent) 10%,#fff);
  border:1px solid color-mix(in srgb,var(--ie-accent) 25%,#fff);
  padding:.3rem .75rem;border-radius:999px;margin-bottom:18px;
}
.ie-hero h1{margin-bottom:.5em}
.ie-hero__sub{font-size:1.15rem;color:var(--ie-muted);max-width:640px}
.ie-hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.ie-hero__points{
  display:flex;gap:22px;flex-wrap:wrap;margin-top:30px;padding:0;list-style:none;
  color:var(--ie-muted);font-size:.92rem;
}
.ie-hero__points li::before{content:"✓";color:var(--ie-accent);font-weight:700;margin-right:7px}

/* Deliverable chips (hero) */
.ie-chips{display:flex;flex-wrap:wrap;gap:10px;list-style:none;margin:30px 0 0;padding:0}
.ie-chips li{
  background:var(--ie-soft);color:var(--ie-accent);
  border:1px solid var(--ie-border);border-radius:999px;
  padding:.4rem 1rem;font-family:var(--ie-font-head);font-weight:600;font-size:.88rem;
}
.ie-write-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}

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

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

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

/* FAQ */
.ie-faq{max-width:820px}
.ie-faq__item{
  background:var(--ie-surface);border:1px solid var(--ie-border);
  border-radius:var(--ie-radius);padding:0;margin-bottom:12px;overflow:hidden;
}
.ie-faq__item summary{
  cursor:pointer;list-style:none;padding:18px 22px;
  font-family:var(--ie-font-head);font-weight:600;font-size:1.02rem;
  position:relative;padding-right:52px;
}
.ie-faq__item summary::-webkit-details-marker{display:none}
.ie-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(--ie-soft);color:var(--ie-accent);font-weight:700;
}
.ie-faq__item[open] summary::after{content:"–"}
.ie-faq__item[open] summary{border-bottom:1px solid var(--ie-border)}
.ie-faq__item p{margin:0;padding:16px 22px 20px;color:var(--ie-muted);font-size:.96rem}

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

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

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

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

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

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

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

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

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