/*
Theme Name: Product Stoic
Theme URI: https://theproductstoic.com
Author: The Product Stoic
Author URI: https://theproductstoic.com
Description: A bespoke quiet-luxury theme for The Product Stoic. Obsidian and antique gold, Lora serif, Roman numeral accents. Built for field notes and the QA-to-Product transition.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 7.0
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: product-stoic
*/

/* ===== Fonts (self-hosted Lora, variable) ===== */
@font-face{
  font-family:'Lora';
  src:url('assets/fonts/Lora.woff') format('woff');
  font-weight:400 700;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'Lora';
  src:url('assets/fonts/Lora-Italic.woff') format('woff');
  font-weight:400 700;
  font-style:italic;
  font-display:swap;
}

/* ===== Tokens ===== */
:root{
  --obsidian:#0E1014;
  --obsidian-2:#12151B;
  --ink:#15181E;
  --porcelain:#ECE7DD;
  --body:#D6D2C8;
  --muted:#969CA5;
  --gold:#C6A15B;
  --gold-light:#D9BD86;
  --line:rgba(236,231,221,.10);
  --gold-line:rgba(198,161,91,.30);
  --serif:'Lora',Georgia,'Times New Roman',serif;
  --wrap:1120px;
  --read:720px;
  --r:16px;
}

/* ===== Reset / base ===== */
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--obsidian);
  color:var(--body);
  font-family:var(--serif);
  font-size:19px;
  line-height:1.75;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--gold-light);text-decoration:none;transition:color .2s ease,opacity .2s ease;}
a:hover{color:var(--gold);}
h1,h2,h3,h4{font-family:var(--serif);color:var(--porcelain);font-weight:600;line-height:1.18;letter-spacing:-.01em;margin:0 0 .5em;}
h1{font-size:clamp(2.3rem,5vw,3.5rem);font-weight:500;}
h2{font-size:clamp(1.8rem,3.2vw,2.4rem);font-weight:500;}
h3{font-size:1.4rem;}
p{margin:0 0 1.3em;}
strong{color:var(--porcelain);font-weight:600;}
hr{border:0;height:1px;background:var(--line);margin:3rem 0;}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
::selection{background:rgba(198,161,91,.28);color:var(--porcelain);}

.skip-link{position:absolute;left:-9999px;}
.skip-link:focus{left:1rem;top:1rem;z-index:100;background:var(--gold);color:var(--obsidian);padding:.6rem 1rem;border-radius:8px;}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px;}
.read{max-width:var(--read);margin:0 auto;padding:0 28px;}

/* ===== Shared display bits ===== */
.kicker{
  display:flex;align-items:center;gap:16px;
  font-size:.82rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:1.4rem;
}
.kicker .num{font-style:italic;font-weight:600;letter-spacing:.04em;color:var(--gold-light);font-size:1rem;text-transform:none;}
.kicker .rule{flex:1;height:1px;background:linear-gradient(90deg,var(--gold-line),transparent);}
.lead{font-size:1.28rem;line-height:1.65;color:var(--body);}
.muted{color:var(--muted);}

/* ===== Buttons ===== */
.btn,.wp-block-button__link{
  display:inline-block;font-family:var(--serif);font-size:1.02rem;font-weight:600;
  letter-spacing:.01em;padding:.85rem 1.7rem;border-radius:999px;cursor:pointer;
  background:linear-gradient(180deg,var(--gold-light),var(--gold));color:#181206;
  border:1px solid transparent;transition:transform .2s ease,box-shadow .2s ease;
  box-shadow:0 18px 40px -22px rgba(198,161,91,.7);
}
.btn:hover,.wp-block-button__link:hover{color:#181206;transform:translateY(-1px);box-shadow:0 22px 46px -20px rgba(198,161,91,.8);}
.btn-ghost{
  display:inline-block;font-family:var(--serif);font-size:1.02rem;font-weight:600;
  padding:.85rem 1.7rem;border-radius:999px;background:transparent;color:var(--porcelain);
  border:1px solid var(--gold-line);transition:border-color .2s ease,color .2s ease;
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-light);}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(14,16,20,.82);backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:24px;height:76px;}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);}
.brand .wordmark{font-size:1.15rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--porcelain);}
.brand img{max-height:40px;width:auto;}
.brand:hover .wordmark{color:var(--gold-light);}
.nav-menu{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0;}
.nav-menu a{color:var(--body);font-size:.98rem;letter-spacing:.02em;}
.nav-menu a:hover,.nav-menu .current-menu-item>a{color:var(--gold-light);}
.nav-cta{margin-left:6px;}
.menu-toggle{display:none;background:none;border:1px solid var(--gold-line);color:var(--porcelain);
  border-radius:10px;padding:.5rem .7rem;font-size:1rem;cursor:pointer;font-family:var(--serif);}

/* ===== Hero ===== */
.hero{
  position:relative;padding:clamp(5rem,12vw,9rem) 0 clamp(4rem,8vw,7rem);
  background:radial-gradient(1200px 640px at 50% -8%,#181C24 0%,var(--obsidian) 62%);
  border-bottom:1px solid var(--line);text-align:center;
}
.hero h1{margin:0 auto .8rem;max-width:16ch;}
.hero .lead{max-width:60ch;margin:0 auto 2.2rem;}
.hero .btn-row{justify-content:center;}
.hero .kicker{justify-content:center;}
.hero .kicker .rule{max-width:60px;}

/* ===== Sections ===== */
.section{padding:clamp(4rem,8vw,6.5rem) 0;border-bottom:1px solid var(--line);}
.section--tight{padding:clamp(3rem,6vw,4.5rem) 0;}
.section h2{max-width:22ch;}
.section-intro{max-width:60ch;color:var(--body);font-size:1.12rem;}

/* Manifesto strip */
.manifesto{background:var(--obsidian-2);text-align:center;}
.manifesto p{font-size:clamp(1.35rem,2.6vw,1.9rem);line-height:1.5;color:var(--porcelain);
  max-width:26ch;margin:0 auto;font-style:italic;}
.manifesto .attrib{font-style:normal;font-size:.85rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-top:1.6rem;}

/* Field notes cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:2.6rem;}
.card{
  background:var(--ink);border:1px solid var(--line);border-radius:var(--r);
  padding:30px 28px 26px;display:flex;flex-direction:column;transition:border-color .25s ease,transform .25s ease;
}
.card:hover{border-color:var(--gold-line);transform:translateY(-3px);}
.card .cat{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:.9rem;}
.card h3{font-size:1.28rem;line-height:1.3;margin-bottom:.6rem;}
.card h3 a{color:var(--porcelain);}
.card h3 a:hover{color:var(--gold-light);}
.card .excerpt{color:var(--muted);font-size:1rem;line-height:1.6;flex:1;}
.card .more{margin-top:1.3rem;font-size:.92rem;letter-spacing:.02em;color:var(--gold-light);}
.card .more:hover{color:var(--gold);}

/* QA Stoic band */
.qastoic{background:linear-gradient(180deg,#12151B,#0E1014);}
.qastoic .panel{
  border:1px solid var(--gold-line);border-radius:22px;padding:clamp(2.4rem,5vw,3.6rem);
  background:radial-gradient(900px 400px at 100% 0%,rgba(198,161,91,.08),transparent 60%),var(--ink);
  display:grid;grid-template-columns:1.3fr .9fr;gap:40px;align-items:center;
}
.qastoic .panel h2{margin-top:.4rem;}
.qastoic .tag{font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);}
.qastoic .aside{border-left:1px solid var(--gold-line);padding-left:34px;}
.qastoic .aside ul{list-style:none;margin:0;padding:0;}
.qastoic .aside li{position:relative;padding-left:22px;margin-bottom:1rem;color:var(--body);font-size:1.02rem;line-height:1.5;}
.qastoic .aside li::before{content:'';position:absolute;left:0;top:.6em;width:7px;height:7px;border-radius:50%;background:var(--gold);}
.invite{font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:1.4rem;}

/* Newsletter */
.newsletter{background:var(--obsidian-2);text-align:center;}
.newsletter .box{max-width:640px;margin:0 auto;}
.subscribe-form{display:flex;gap:12px;max-width:520px;margin:2rem auto 0;}
.subscribe-form input[type=email]{
  flex:1;background:var(--obsidian);border:1px solid var(--gold-line);border-radius:999px;
  color:var(--porcelain);font-family:var(--serif);font-size:1rem;padding:.85rem 1.3rem;
}
.subscribe-form input[type=email]::placeholder{color:var(--muted);}
.subscribe-form input[type=email]:focus{outline:none;border-color:var(--gold);}
.provider-note{margin-top:1.1rem;font-size:.82rem;color:var(--muted);}

/* Lead magnet */
.leadmagnet .panel{
  display:grid;grid-template-columns:.8fr 1.2fr;gap:36px;align-items:center;
  border:1px solid var(--line);border-radius:22px;background:var(--ink);padding:clamp(2rem,4vw,3rem);
}
.leadmagnet .cover{aspect-ratio:3/4;border-radius:12px;border:1px solid var(--gold-line);
  background:radial-gradient(600px 300px at 30% 0%,#1B1F27,#0E1014);display:flex;align-items:center;justify-content:center;text-align:center;}
.leadmagnet .cover span{font-style:italic;color:var(--gold-light);font-size:1.15rem;padding:1.4rem;line-height:1.4;}

/* ===== Article (single / page) ===== */
.article-header{padding:clamp(3.5rem,8vw,6rem) 0 1.5rem;text-align:center;border-bottom:1px solid var(--line);
  background:radial-gradient(1000px 480px at 50% -10%,#181C24,var(--obsidian) 60%);}
.article-header h1{max-width:20ch;margin:0 auto .6rem;}
.article-meta{color:var(--muted);font-size:.9rem;letter-spacing:.04em;}
.article-meta .sep{color:var(--gold);margin:0 .6rem;}
.entry{padding:3rem 0 4rem;}
.entry p{color:var(--body);}
.entry>*{max-width:var(--read);margin-left:auto;margin-right:auto;}
.entry .alignwide{max-width:1000px;}
.entry .alignfull{max-width:none;}
.entry h2{margin-top:2.4rem;}
.entry h3{margin-top:2rem;color:var(--gold-light);}
.entry img,.entry figure{border-radius:12px;}
.entry figure{margin:2.2rem auto;}
.entry figcaption,.wp-element-caption{color:var(--muted);font-size:.86rem;text-align:center;margin-top:.7rem;font-style:italic;}
.entry blockquote,.wp-block-quote{
  border-left:2px solid var(--gold);padding:.2rem 0 .2rem 1.6rem;margin:2rem auto;
  font-style:italic;color:var(--porcelain);font-size:1.2rem;
}
.entry ul,.entry ol{color:var(--body);padding-left:1.3rem;margin:0 auto 1.4rem;max-width:var(--read);}
.entry li{margin-bottom:.6rem;}
.entry a{border-bottom:1px solid var(--gold-line);}
.entry a:hover{border-color:var(--gold);}
.entry code{background:var(--ink);border:1px solid var(--line);border-radius:6px;padding:.1rem .4rem;font-size:.9em;}
.entry pre{background:var(--ink);border:1px solid var(--line);border-radius:12px;padding:1.2rem;overflow:auto;}
.dropcap:first-letter{}
.article-cta{max-width:var(--read);margin:2rem auto 0;padding:2rem;border:1px solid var(--gold-line);
  border-radius:18px;background:var(--ink);text-align:center;}
.article-cta .tag{font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);}
.article-cta h3{color:var(--porcelain);margin:.7rem 0 1rem;}

/* Archive / listing header */
.page-hero{padding:clamp(3.5rem,8vw,5.5rem) 0 2.5rem;text-align:center;border-bottom:1px solid var(--line);
  background:radial-gradient(1000px 480px at 50% -10%,#181C24,var(--obsidian) 60%);}
.list-wrap{padding:3.5rem 0 4.5rem;}

/* Pagination */
.pagination{display:flex;gap:10px;justify-content:center;margin-top:3rem;flex-wrap:wrap;}
.pagination .page-numbers{border:1px solid var(--gold-line);border-radius:10px;padding:.5rem .9rem;color:var(--body);}
.pagination .current{background:var(--gold);color:var(--obsidian);border-color:var(--gold);}
.pagination a:hover{border-color:var(--gold);color:var(--gold-light);}

/* Comments (minimal) */
.comments{max-width:var(--read);margin:3rem auto 0;padding-top:2rem;border-top:1px solid var(--line);}
.comments h3{color:var(--porcelain);}
.comment-list{list-style:none;padding:0;}
.comment-body{border:1px solid var(--line);border-radius:12px;padding:1.2rem;margin-bottom:1rem;background:var(--ink);}
.comment-form input,.comment-form textarea{width:100%;background:var(--obsidian);border:1px solid var(--gold-line);
  border-radius:10px;color:var(--porcelain);font-family:var(--serif);padding:.7rem 1rem;margin-bottom:1rem;}

/* ===== Footer ===== */
.site-footer{background:var(--obsidian-2);border-top:1px solid var(--line);padding:4rem 0 2.4rem;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;align-items:start;}
.footer-brand .wordmark{font-size:1.1rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--porcelain);}
.footer-brand p{color:var(--muted);font-size:.98rem;margin-top:1rem;max-width:36ch;}
.footer-col h4{font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:1.1rem;}
.footer-col ul{list-style:none;margin:0;padding:0;}
.footer-col li{margin-bottom:.7rem;}
.footer-col a{color:var(--body);font-size:.98rem;}
.footer-col a:hover{color:var(--gold-light);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;
  margin-top:3rem;padding-top:1.8rem;border-top:1px solid var(--line);flex-wrap:wrap;}
.footer-bottom .maxim{font-style:italic;color:var(--porcelain);font-size:1.05rem;}
.footer-bottom .copy{color:var(--muted);font-size:.84rem;letter-spacing:.04em;}

/* ===== Responsive ===== */
@media(max-width:900px){
  .cards{grid-template-columns:1fr 1fr;}
  .qastoic .panel{grid-template-columns:1fr;}
  .qastoic .aside{border-left:0;border-top:1px solid var(--gold-line);padding-left:0;padding-top:26px;}
  .leadmagnet .panel{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  body{font-size:18px;}
  .nav-menu{
    display:none;position:absolute;top:76px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--obsidian);border-bottom:1px solid var(--line);padding:8px 0;
  }
  .nav-menu.open{display:flex;}
  .nav-menu li{padding:.4rem 28px;}
  .nav-cta{padding:1rem 28px 1.2rem;}
  .menu-toggle{display:inline-block;}
  .cards{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
  .subscribe-form{flex-direction:column;border-radius:16px;}
  .subscribe-form input[type=email]{width:100%;}
}

/* ===== Testimonials ===== */
.testimonials{background:var(--obsidian-2);}
.testimonials .kicker{margin-bottom:0;}
.testimonial-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:2.6rem;}
.testimonial{
  position:relative;margin:0;background:var(--ink);border:1px solid var(--line);
  border-radius:16px;padding:44px 32px 30px;
}
.testimonial::before{
  content:'\201C';position:absolute;top:16px;left:26px;
  font-family:var(--serif);font-size:3rem;line-height:1;color:var(--gold);opacity:.4;
}
.testimonial blockquote{
  margin:0 0 1.1rem;padding:0;border:0;font-style:italic;
  color:var(--porcelain);font-size:1.16rem;line-height:1.55;
}
.testimonial blockquote p{margin:0 0 .6em;}
.testimonial blockquote p:last-child{margin-bottom:0;}
.testimonial figcaption{
  font-style:normal;font-size:.84rem;letter-spacing:.06em;
  color:var(--gold-light);text-align:left;margin-top:.4rem;
}
.subscribe-embed{max-width:520px;margin:2rem auto 0;}
@media(max-width:640px){
  .testimonial-grid{grid-template-columns:1fr;}
}
