/*
Theme Name: Parchment & Quill
Theme URI: https://example.com/parchment-quill
Author: krumbz
Author URI: https://example.com
Description: A medieval, ancient-romance inspired WordPress theme with an aged-parchment feel, soft glowing accents, and gentle scroll-driven animations. Includes styled templates for a Home hero, a Blogs "Chronicles" archive, an interactive scored Quiz, and a WooCommerce-ready Products "Merchant's Wares" page.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: parchment-quill
Tags: blog, e-commerce, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready, one-column, two-columns, right-sidebar, theme-options
*/

/* =========================================================
   1. DESIGN TOKENS
   ========================================================= */
:root{
  --parchment-light:#f4e8cf;
  --parchment:#e9d9b5;
  --parchment-dark:#d8c39a;
  --parchment-edge:#c7ad7c;
  --ink:#3a2c1a;
  --ink-soft:#5c4a30;
  --ink-faint:#8a765a;
  --gold:#a9781f;
  --gold-bright:#c9982f;
  --wax-red:#7a1f1f;
  --wax-red-bright:#9c2b2b;
  --forest:#3f4f2e;
  --shadow-deep: rgba(58,44,26,0.45);
  --shadow-soft: rgba(58,44,26,0.18);
  --radius-scroll: 6px;
  --font-display: 'Cinzel', 'Trajan Pro', Georgia, serif;
  --font-accent: 'Uncial Antiqua', 'Cinzel Decorative', cursive;
  --font-body: 'EB Garamond', 'IM Fell English', Georgia, serif;
  --content-width: 1180px;
  --transition-slow: 900ms cubic-bezier(.22,.61,.36,1);
  --transition-med: 450ms cubic-bezier(.22,.61,.36,1);
  --transition-fast: 220ms ease;
}

/* =========================================================
   2. RESET
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  color:var(--ink);
  font-family:var(--font-body);
  font-size:1.125rem;
  line-height:1.7;
  background-color:var(--parchment);
  background-image:
    radial-gradient(ellipse at 20% 10%, rgba(255,250,230,0.5), transparent 55%),
    radial-gradient(ellipse at 85% 90%, rgba(120,90,40,0.12), transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  background-attachment:fixed;
  overflow-x:hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--wax-red); text-decoration:none; transition:color var(--transition-fast); }
a:hover{ color:var(--gold-bright); }
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  color:var(--ink);
  letter-spacing:.02em;
  line-height:1.25;
  margin:0 0 .6em;
}
h1{ font-size:clamp(2.2rem,4vw,3.4rem); }
h2{ font-size:clamp(1.7rem,3vw,2.4rem); }
h3{ font-size:1.4rem; }
p{ margin:0 0 1.2em; }
ul,ol{ padding-left:1.4em; }
::selection{ background:var(--gold); color:var(--parchment-light); }

/* Ornamental drop cap for long-form content */
.chronicle-content > p:first-of-type::first-letter{
  font-family:var(--font-accent);
  font-size:3.6rem;
  float:left;
  line-height:.8;
  padding:.1em .12em 0 0;
  color:var(--wax-red);
}

/* =========================================================
   3. LAYOUT
   ========================================================= */
.site-wrap{ max-width:var(--content-width); margin:0 auto; padding:0 1.5rem; }
.section{ padding:5rem 0; position:relative; }
.section-narrow{ max-width:820px; margin:0 auto; }
.grid{ display:grid; gap:2rem; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){
  .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
  .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; }
  .section{ padding:3rem 0; }
}

/* =========================================================
   4. HEADER / NAVIGATION
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:100;
  background:linear-gradient(180deg, var(--parchment-light), var(--parchment) 90%);
  border-bottom:2px solid var(--parchment-edge);
  box-shadow:0 6px 18px var(--shadow-soft);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:1rem 1.5rem; max-width:var(--content-width); margin:0 auto;
}
.site-branding{ display:flex; align-items:center; gap:.75rem; }
.site-title{
  font-family:var(--font-accent);
  font-size:1.7rem;
  color:var(--wax-red);
  margin:0;
}
.site-title a{ color:inherit; }
.site-description{ font-size:.85rem; color:var(--ink-faint); margin:0; font-style:italic; }

.primary-navigation ul{
  display:flex; gap:2rem; list-style:none; margin:0; padding:0;
}
.primary-navigation a{
  position:relative;
  font-family:var(--font-display);
  font-size:.95rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--ink);
  padding:.4rem .1rem;
}
.primary-navigation a::after{
  content:"";
  position:absolute; left:0; bottom:-2px;
  width:0; height:2px;
  background:var(--gold-bright);
  box-shadow:0 0 8px var(--gold-bright);
  transition:width var(--transition-med);
}
.primary-navigation a:hover::after,
.primary-navigation a:focus::after,
.primary-navigation .current-menu-item a::after{ width:100%; }
.primary-navigation a:hover{ color:var(--wax-red); animation:torch-flicker 1.4s infinite; }

.menu-toggle{
  display:none; background:none; border:2px solid var(--ink); border-radius:4px;
  padding:.4rem .6rem; cursor:pointer; font-family:var(--font-display);
}
@media (max-width:820px){
  .menu-toggle{ display:inline-block; }
  .primary-navigation{
    display:none; width:100%;
    order:3;
  }
  .primary-navigation.is-open{ display:block; }
  .primary-navigation ul{ flex-direction:column; gap:0; padding:1rem 0; }
  .primary-navigation li{ border-top:1px solid var(--parchment-edge); }
  .primary-navigation a{ display:block; padding:.8rem .2rem; }
  .header-inner{ flex-wrap:wrap; }
}

/* =========================================================
   5. BUTTONS / WAX SEAL
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--font-display);
  letter-spacing:.05em;
  text-transform:uppercase;
  font-size:.85rem;
  padding:.85rem 1.8rem;
  border-radius:999px;
  border:1px solid var(--gold);
  background:linear-gradient(180deg, var(--parchment-light), var(--parchment-dark));
  color:var(--ink);
  cursor:pointer;
  transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  box-shadow:0 3px 0 var(--parchment-edge), 0 6px 14px var(--shadow-soft);
}
.btn:hover{ transform:translateY(-2px); color:var(--parchment-light); background:linear-gradient(180deg, var(--wax-red-bright), var(--wax-red)); border-color:var(--wax-red); }
.btn:active{ transform:translateY(0); }
.btn-seal{
  border-radius:50%; width:64px; height:64px; padding:0; justify-content:center;
  background:radial-gradient(circle at 35% 30%, var(--wax-red-bright), var(--wax-red) 70%);
  color:var(--parchment-light); border:2px solid #5a1414;
  box-shadow:0 4px 10px var(--shadow-deep), inset 0 0 10px rgba(0,0,0,.35);
}

/* =========================================================
   6. CARDS (scroll / manuscript feel)
   ========================================================= */
.scroll-card{
  position:relative;
  background:var(--parchment-light);
  border:1px solid var(--parchment-edge);
  border-radius:var(--radius-scroll);
  padding:2rem;
  box-shadow:0 10px 24px var(--shadow-soft), inset 0 0 40px rgba(120,90,40,.08);
  transition:transform var(--transition-med), box-shadow var(--transition-med);
}
.scroll-card:hover{ transform:translateY(-6px); box-shadow:0 18px 34px var(--shadow-soft); }
.scroll-card::before,
.scroll-card::after{
  content:""; position:absolute; left:6%; right:6%; height:14px;
  background:radial-gradient(ellipse at center, var(--parchment-dark) 40%, transparent 70%);
  filter:blur(1px);
}
.scroll-card::before{ top:-7px; }
.scroll-card::after{ bottom:-7px; }

.card-media{ border-radius:4px; overflow:hidden; margin-bottom:1rem; border:1px solid var(--parchment-edge); }
.card-media img{ transition:transform var(--transition-slow); }
.scroll-card:hover .card-media img{ transform:scale(1.06); }

/* =========================================================
   7. HERO (Home)
   ========================================================= */
.hero{
  position:relative; text-align:center; padding:7rem 1.5rem 5rem;
  overflow:hidden;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(201,152,47,.25), transparent 60%);
}
.hero-inner{ position:relative; z-index:1; max-width:760px; margin:0 auto; }
.hero-eyebrow{
  font-family:var(--font-accent); color:var(--wax-red); letter-spacing:.08em; margin-bottom:.5rem;
  opacity:0; animation:unfurl-fade 1.1s ease forwards .1s;
}
.hero-title{ opacity:0; animation:unfurl-fade 1.1s ease forwards .35s; }
.hero-sub{ opacity:0; animation:unfurl-fade 1.1s ease forwards .6s; color:var(--ink-soft); font-size:1.2rem; }
.hero-cta{ opacity:0; animation:unfurl-fade 1.1s ease forwards .85s; margin-top:1.5rem; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

.hero-scroll-frame{
  max-width:900px; margin:3rem auto 0; padding:2px;
  background:linear-gradient(90deg, var(--gold), var(--wax-red), var(--gold));
  border-radius:10px;
  opacity:0; transform:scaleY(0); transform-origin:top center;
  animation:scroll-unfurl 1.2s cubic-bezier(.22,.61,.36,1) forwards 1.1s;
}
.hero-scroll-frame-inner{ background:var(--parchment-light); border-radius:8px; padding:2.5rem; }

/* =========================================================
   8. FOOTER
   ========================================================= */
.site-footer{
  margin-top:4rem; padding:3rem 0 2rem;
  background:linear-gradient(0deg, var(--parchment-dark), var(--parchment));
  border-top:2px solid var(--parchment-edge);
  text-align:center; color:var(--ink-soft); font-size:.95rem;
}
.site-footer a{ color:var(--ink-soft); text-decoration:underline; }
.footer-ornament{ font-family:var(--font-accent); font-size:1.4rem; color:var(--gold); margin-bottom:.6rem; }

/* =========================================================
   9. UTILITIES
   ========================================================= */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .9s ease, transform .9s ease; }
.reveal.is-visible{ opacity:1; transform:none; }
.center{ text-align:center; }
.tag{
  display:inline-block; font-size:.75rem; text-transform:uppercase; letter-spacing:.08em;
  background:var(--parchment-dark); color:var(--ink-soft); padding:.25rem .7rem; border-radius:999px; margin:0 .3rem .3rem 0;
}
.divider-ornament{ text-align:center; margin:2.5rem 0; color:var(--gold); font-size:1.5rem; letter-spacing:1rem; opacity:.7; }

/* =========================================================
   10. QUIZ CHAMBER
   ========================================================= */
.quiz-shell{
  max-width:720px; margin:0 auto;
  background:var(--parchment-light);
  border:1px solid var(--parchment-edge);
  border-radius:var(--radius-scroll);
  padding:2.5rem;
  box-shadow:0 14px 34px var(--shadow-soft);
}
.quiz-progress-track{
  width:100%; height:8px; border-radius:999px; background:var(--parchment-dark);
  overflow:hidden; margin-bottom:.6rem;
}
.quiz-progress-bar{
  height:100%; width:100%; transform-origin:left center; transform:scaleX(0);
  background:linear-gradient(90deg, var(--gold), var(--wax-red));
  transition:transform .5s ease;
}
.quiz-progress-label{ font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:2rem; display:block; }
.quiz-answers{ display:grid; gap:1rem; margin-top:1.5rem; }
.quiz-answer{ width:100%; justify-content:flex-start; text-align:left; border-radius:8px; padding:1rem 1.4rem; text-transform:none; letter-spacing:normal; font-family:var(--font-body); font-size:1.05rem; }
.quiz-intro{ text-align:center; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}
