/*
Theme Name: SO What Works
Theme URI: https://sowhat.works
Author: Stephen Owen
Author URI: https://sowhat.works
Description: The official SO What Works? theme for GROWTH by DESIGN. A warm, editorial, classic WordPress theme built for author publishing and direct book sales with WooCommerce and BookVault. No page builder required: everything is set through the WordPress Customizer and admin.
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: sowhatworks
Tags: blog, e-commerce, custom-menu, featured-images, threaded-comments, translation-ready, editor-style, custom-logo, two-columns
*/

/* ============================================================
   1. TOKENS
   ============================================================ */
:root{
  --cream:#F2EAD2;        /* page background */
  --cream-deep:#EFE3C2;   /* alt sections */
  --plaque:#E7D2A8;       /* soft tan chips/cards */
  --brown:#6A4630;        /* headings */
  --copper:#B26A30;       /* primary accent / links / buttons */
  --copper-bright:#C2792F;
  --char:#3D3024;         /* body text */
  --sage:#94A064;         /* muted labels */
  --lemon:#EFB840;        /* highlights */
  --accent-yellow:#FFD633; --accent-green:#88C057; --accent-orange:#FF9900; --ink:#111111;
  --line:rgba(106,70,48,.14);
  --font-display:'Fraunces',Georgia,serif;
  --font-body:'Lora',Georgia,serif;
  --font-ui:'Montserrat',system-ui,sans-serif;
  --wrap:1240px;
  --radius:14px;
}

/* ============================================================
   2. BASE
   ============================================================ */
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
html,body{margin:0;padding:0;}
body{
  background:var(--cream);
  background-image:url('assets/img/grain.png');
  background-repeat:repeat;
  color:var(--char);
  font-family:var(--font-body);
  font-size:18px;
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--brown);font-weight:880;line-height:1.05;margin:0 0 .5em;}
h1{font-size:clamp(2.4rem,5vw,4rem);} h2{font-size:clamp(1.8rem,3.5vw,2.6rem);}
h3{font-size:1.5rem;} h4{font-size:1.2rem;}
p{margin:0 0 1.1em;}
a{color:var(--copper);text-decoration:none;}
a:hover{color:var(--copper-bright);text-decoration:underline;}
ul,ol{padding-left:1.3em;}
blockquote{
  border-left:4px solid var(--copper);
  margin:1.6em 0;padding:.4em 0 .4em 1.4em;
  font-family:var(--font-display);font-style:italic;color:var(--brown);font-size:1.25rem;
}
code,pre{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--plaque);border-radius:6px;}
code{padding:.1em .4em;font-size:.9em;}
pre{padding:1em 1.2em;overflow:auto;}
hr{border:none;border-top:1px solid var(--line);margin:2.4em 0;}
.i,.italic{font-family:var(--font-display);font-style:italic;font-weight:480;color:var(--copper);}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 40px;}
.eyebrow{font-family:var(--font-ui);font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--sage);font-size:.82rem;}
.chip{font-family:var(--font-ui);font-weight:700;background:var(--plaque);color:var(--copper-bright);padding:.3em 1em;border-radius:999px;display:inline-block;font-size:.85rem;}
.section-alt,.alt{background:var(--cream-deep);}

/* ============================================================
   3. ACCESSIBILITY
   ============================================================ */
.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;
  margin:-1px;overflow:hidden;padding:0;position:absolute !important;word-wrap:normal !important;
}
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:100000;
  background:var(--brown);color:var(--cream);padding:.7em 1.2em;font-family:var(--font-ui);font-weight:700;border-radius:0 0 8px 0;
}
.skip-link:focus{left:0;color:var(--cream);text-decoration:none;}
a:focus,button:focus,input:focus,textarea:focus,select:focus{outline:3px solid var(--copper);outline-offset:2px;}

/* ============================================================
   4. BUTTONS & FORMS
   ============================================================ */
.btn,button,input[type="submit"],
.wp-block-button__link,
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit,.woocommerce .button{
  font-family:var(--font-ui);font-weight:700;display:inline-block;cursor:pointer;
  padding:.85em 1.7em;border-radius:10px;letter-spacing:.3px;line-height:1.2;
  background:var(--copper);color:var(--cream) !important;border:2.5px solid var(--copper);
  transition:background .15s ease,border-color .15s ease;
}
.btn:hover,button:hover,input[type="submit"]:hover,
.wp-block-button__link:hover,
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce .button:hover{
  background:var(--copper-bright);border-color:var(--copper-bright);color:var(--cream) !important;text-decoration:none;
}
.btn.ghost,.btn-ghost{background:transparent;color:var(--brown) !important;}
.btn.ghost:hover,.btn-ghost:hover{background:rgba(178,106,48,.08);color:var(--brown) !important;border-color:var(--copper);}

input[type="text"],input[type="email"],input[type="url"],input[type="password"],input[type="search"],
input[type="number"],input[type="tel"],textarea,select{
  font-family:var(--font-body);font-size:1rem;width:100%;max-width:100%;
  padding:.7em .9em;border:1.5px solid var(--line);border-radius:8px;background:#fff;color:var(--char);
}
label{font-family:var(--font-ui);font-weight:700;font-size:.9rem;color:var(--brown);display:block;margin-bottom:.35em;}

/* ============================================================
   5. HEADER / NAV
   ============================================================ */
.site-header{position:relative;z-index:50;}
.nav{display:flex;align-items:center;justify-content:space-between;padding:22px 0;gap:20px;}
.nav .site-logo img,.nav .site-logo .custom-logo{height:42px;width:auto;display:block;}
.nav .site-logo .site-title-text{font-family:var(--font-display);font-weight:880;color:var(--brown);font-size:1.4rem;}
.nav-toggle{display:none;background:none;border:2px solid var(--copper);color:var(--brown) !important;border-radius:8px;padding:.4em .6em;font-size:1.2rem;line-height:1;}
.nav-menu{display:flex;gap:34px;align-items:center;font-family:var(--font-ui);font-weight:700;font-size:.95rem;list-style:none;margin:0;padding:0;}
.nav-menu li{position:relative;}
.nav-menu a{color:var(--brown);display:block;}
.nav-menu a:hover,.nav-menu .current-menu-item > a{color:var(--copper);text-decoration:none;}
.nav-menu .sub-menu{
  display:none;position:absolute;top:100%;left:0;min-width:200px;background:var(--cream);
  border:1px solid var(--line);border-radius:10px;padding:10px;box-shadow:0 8px 24px rgba(61,48,36,.14);
}
.nav-menu li:hover > .sub-menu,.nav-menu li:focus-within > .sub-menu{display:block;}
.nav-menu .sub-menu a{padding:.4em .6em;border-radius:6px;}
.nav-menu .sub-menu a:hover{background:var(--plaque);}
.nav-cta{background:transparent;color:var(--brown) !important;border:2px solid var(--copper);border-radius:10px;padding:.55em 1.2em;}
.nav-cta:hover{background:rgba(178,106,48,.08);}

/* ============================================================
   6. HERO (front page)
   ============================================================ */
.hero{display:flex;align-items:center;gap:40px;padding:40px 0 80px;}
.hero .col{flex:1;min-width:0;}
.hero h1{font-size:clamp(2.6rem,5vw,4.4rem);margin:18px 0 24px;}
.hero .sub{font-size:1.45rem;max-width:560px;margin-bottom:34px;}
.hero .cta{display:flex;gap:18px;flex-wrap:wrap;}
.hero .art img{width:100%;max-width:620px;margin-left:auto;}

/* ============================================================
   7. SECTIONS (front page)
   ============================================================ */
.section{padding:84px 0;}
.section .center{text-align:center;max-width:720px;margin:0 auto 54px;}
.section .center h2{font-size:clamp(2rem,3.6vw,2.8rem);margin-bottom:16px;}
.section .center p{font-size:1.2rem;color:var(--char);}

/* systems */
.systems{display:flex;gap:34px;}
.syscard{flex:1;background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:40px;}
.syscard .tag{font-family:var(--font-ui);font-weight:800;letter-spacing:1px;color:var(--copper);font-size:.8rem;text-transform:uppercase;}
.syscard h3{font-size:1.9rem;margin:8px 0 6px;}
.syscard .lead{font-style:italic;color:var(--copper);font-family:var(--font-display);font-size:1.15rem;margin-bottom:22px;}
.syscard ul{list-style:none;margin:0;padding:0;}
.syscard li{padding:10px 0;border-top:1px solid rgba(106,70,48,.1);font-size:1.05rem;}
.syscard li b{font-family:var(--font-display);color:var(--brown);}
.syscard li .k{display:inline-block;width:1.4em;color:var(--copper-bright);font-family:var(--font-display);font-weight:880;}

/* books */
.books{display:flex;gap:30px;align-items:flex-end;}
.book{flex:1;text-align:center;}
.book img{max-width:300px;margin:0 auto 22px;}
.book h3{font-size:1.4rem;margin-bottom:6px;}
.book p{font-size:1rem;color:var(--char);min-height:48px;margin:0 0 16px;}
.book .price{font-family:var(--font-ui);font-weight:700;color:var(--copper-bright);margin:0 0 14px;}

/* magnet */
.magnet{background:var(--brown);color:var(--cream);border-radius:24px;padding:60px;text-align:center;}
.magnet h2{color:var(--cream);font-size:clamp(2rem,3.4vw,2.7rem);margin-bottom:14px;}
.magnet p{font-size:1.25rem;max-width:620px;margin:0 auto 30px;color:#F2E6CC;}
.magnet .btn{background:var(--lemon);border-color:var(--lemon);color:#4a3410 !important;}
.magnet .btn:hover{background:#f3c659;border-color:#f3c659;color:#4a3410 !important;}
.magnet form{max-width:460px;margin:0 auto;}

/* flipbook */
.flip-section{text-align:center;}
.flipbook-shell{max-width:900px;margin:0 auto;}
#flipbook{margin:0 auto;touch-action:pan-y;}
.flip-controls{margin-top:22px;display:flex;gap:14px;justify-content:center;}

/* about */
.about{display:flex;gap:50px;align-items:center;}
.about .ic{flex:0 0 200px;text-align:center;}
.about .ic img{width:150px;margin:0 auto;}
.about h2{font-size:2.2rem;margin-bottom:18px;}
.about p{font-size:1.18rem;margin-bottom:16px;}

/* ============================================================
   8. BLOG / ARCHIVE / SINGLE
   ============================================================ */
.content-area{padding:60px 0 90px;}
.site-main-title{margin-bottom:40px;}
.site-main-title h1{font-size:clamp(2rem,4vw,3rem);}
.site-main-title .archive-desc{font-size:1.15rem;color:var(--char);max-width:680px;}

.layout{display:flex;gap:56px;align-items:flex-start;}
.layout .primary{flex:1;min-width:0;}
.layout .sidebar{flex:0 0 300px;}

.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:38px;}
.card{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;}
.card .thumb img{width:100%;aspect-ratio:16/9;object-fit:cover;}
.card .card-body{padding:26px 28px 30px;display:flex;flex-direction:column;flex:1;}
.card .meta{font-family:var(--font-ui);font-size:.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--sage);margin-bottom:10px;}
.card h2,.card h3{font-size:1.5rem;margin-bottom:10px;}
.card h2 a,.card h3 a{color:var(--brown);}
.card h2 a:hover,.card h3 a:hover{color:var(--copper);text-decoration:none;}
.card .excerpt{font-size:1rem;margin-bottom:18px;flex:1;}
.card .read-more{font-family:var(--font-ui);font-weight:700;font-size:.9rem;}

.single-post .entry-header{margin-bottom:34px;}
.single-post .entry-header .cats{margin-bottom:14px;}
.single-post .entry-header h1{font-size:clamp(2.2rem,4.5vw,3.4rem);margin-bottom:16px;}
.single-post .entry-meta{font-family:var(--font-ui);font-size:.85rem;font-weight:700;letter-spacing:.5px;color:var(--sage);}
.single-post .featured{margin:0 0 40px;border-radius:var(--radius);overflow:hidden;}
.entry-content{font-size:1.15rem;}
.entry-content h2{margin-top:1.6em;}
.entry-content h3{margin-top:1.4em;}
.entry-content img{border-radius:10px;margin:1.4em 0;}
.entry-content a{text-decoration:underline;}
.entry-footer{margin-top:44px;padding-top:26px;border-top:1px solid var(--line);font-family:var(--font-ui);font-size:.9rem;}
.entry-footer .tags a{display:inline-block;margin:0 8px 8px 0;}

.post-nav{display:flex;justify-content:space-between;gap:20px;margin:50px 0;font-family:var(--font-ui);font-weight:700;}
.post-nav .nav-previous,.post-nav .nav-next{max-width:48%;}

/* pagination */
.pagination{margin:50px 0 0;display:flex;gap:10px;flex-wrap:wrap;font-family:var(--font-ui);font-weight:700;}
.pagination .page-numbers{padding:.5em .9em;border-radius:8px;border:1.5px solid var(--line);color:var(--brown);}
.pagination .page-numbers.current{background:var(--copper);color:var(--cream);border-color:var(--copper);}
.pagination a.page-numbers:hover{background:var(--plaque);text-decoration:none;}

/* ============================================================
   9. SIDEBAR / WIDGETS / SEARCH
   ============================================================ */
.widget{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:26px 28px;margin-bottom:30px;}
.widget-title{font-family:var(--font-display);font-size:1.25rem;color:var(--brown);margin-bottom:16px;}
.widget ul{list-style:none;margin:0;padding:0;}
.widget ul li{padding:8px 0;border-top:1px solid rgba(106,70,48,.1);font-family:var(--font-ui);font-size:.95rem;}
.widget ul li:first-child{border-top:none;}
.widget a{color:var(--brown);}
.widget a:hover{color:var(--copper);}
.search-form{display:flex;gap:8px;}
.search-form .search-submit{flex:0 0 auto;padding:.7em 1.1em;}

/* ============================================================
   10. COMMENTS
   ============================================================ */
.comments-area{margin-top:60px;padding-top:40px;border-top:1px solid var(--line);}
.comments-title,.comment-reply-title{font-size:1.6rem;margin-bottom:24px;}
.comment-list{list-style:none;margin:0;padding:0;}
.comment-list li{margin-bottom:26px;}
.comment-body{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;}
.comment-author{font-family:var(--font-ui);font-weight:700;color:var(--brown);}
.comment-meta{font-size:.82rem;color:var(--sage);margin-bottom:8px;}
.comment-list .children{list-style:none;margin:20px 0 0 28px;padding:0;}
.comment-respond{margin-top:40px;}
.comment-form p{margin-bottom:16px;}

/* ============================================================
   11. WOOCOMMERCE
   ============================================================ */
.woocommerce-page .content-area,.woocommerce .content-area{padding:60px 0 90px;}
.woocommerce ul.products{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin:0;padding:0;}
.woocommerce ul.products li.product{list-style:none;text-align:center;background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin:0;}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--font-display);color:var(--brown);font-size:1.25rem;padding:14px 0 6px;}
.woocommerce ul.products li.product .price{font-family:var(--font-ui);font-weight:700;color:var(--copper-bright);display:block;margin-bottom:14px;}
.woocommerce span.price,.woocommerce div.product p.price{color:var(--copper-bright);font-family:var(--font-ui);font-weight:700;}
.woocommerce div.product .product_title{font-family:var(--font-display);}
.woocommerce .star-rating span{color:var(--copper);}
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-top-color:var(--copper);font-family:var(--font-ui);}
.woocommerce-message::before,.woocommerce-info::before{color:var(--copper);}
.woocommerce nav.woocommerce-pagination ul{border-color:var(--line);}

/* ============================================================
   12. FOOTER
   ============================================================ */
.site-footer{background:var(--brown);color:var(--cream);padding:60px 0 36px;margin-top:0;}
.site-footer a{color:#EADFC6;}
.site-footer a:hover{color:#fff;}
.site-footer .top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.site-footer img.footer-logo{height:40px;width:auto;}
.site-footer .fcol{min-width:150px;}
.site-footer .fcol.brand{max-width:300px;}
.site-footer .fcol p{color:#EADFC6;margin-top:16px;font-size:.95rem;}
.site-footer .fcol h4{font-family:var(--font-ui);font-weight:800;letter-spacing:1px;text-transform:uppercase;font-size:.78rem;color:var(--lemon);margin:0 0 14px;}
.site-footer .fcol a{display:block;font-family:var(--font-ui);font-size:.95rem;margin-bottom:9px;}
.site-footer .fcol ul{list-style:none;margin:0;padding:0;}
.site-footer .legal{border-top:1px solid rgba(255,255,255,.15);margin-top:40px;padding-top:22px;font-family:var(--font-ui);font-size:.82rem;color:#cdbb9c;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}

/* ============================================================
   13. WP CORE ALIGNMENT & CAPTIONS
   ============================================================ */
.alignleft{float:left;margin:.4em 1.6em 1em 0;}
.alignright{float:right;margin:.4em 0 1em 1.6em;}
.aligncenter{margin-left:auto;margin-right:auto;display:block;}
.alignwide{max-width:1100px;margin-left:auto;margin-right:auto;}
.alignfull{max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);}
.wp-caption{max-width:100%;}
.wp-caption-text,.wp-block-image figcaption{font-family:var(--font-ui);font-size:.85rem;color:var(--sage);text-align:center;margin-top:.5em;}
.sticky .card{border-color:var(--copper);}
.post-password-form input[type="password"]{max-width:280px;}

/* ============================================================
   14. RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .post-grid{grid-template-columns:1fr;}
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr);}
  .layout{flex-direction:column;}
  .layout .sidebar{flex:1 1 auto;width:100%;}
}
@media(max-width:860px){
  .wrap{padding:0 24px;}
  .nav-toggle{display:inline-block;}
  .nav-menu{
    display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:var(--cream);border:1px solid var(--line);border-radius:0 0 14px 14px;
    padding:10px 18px 18px;box-shadow:0 12px 30px rgba(61,48,36,.16);
  }
  .nav-menu.open{display:flex;}
  .nav-menu li{width:100%;border-top:1px solid rgba(106,70,48,.1);}
  .nav-menu li:first-child{border-top:none;}
  .nav-menu a{padding:.9em 0;}
  .nav-menu .sub-menu{position:static;display:block;border:none;box-shadow:none;padding:0 0 0 14px;background:transparent;}
  .nav-cta{display:inline-block;margin-top:6px;}
  .hero{flex-direction:column;text-align:center;padding:20px 0 60px;}
  .hero .sub{margin-left:auto;margin-right:auto;}
  .hero .cta{justify-content:center;}
  .hero .art img{margin:30px auto 0;}
  .systems,.books,.about{flex-direction:column;}
  .about .ic{flex:1 1 auto;}
  .woocommerce ul.products{grid-template-columns:1fr;}
  .section{padding:60px 0;}
  .magnet{padding:44px 26px;}
  .site-footer .top{gap:28px;}
}
