/*
Theme Name: Tomi Jenkins
Theme URI: https://tfmv.example.com
Author: TOTM Publishing
Author URI: https://tfmv.example.com
Description: Author / artist landing page theme for Tomi Jenkins, writing as Thomas Michael Jenkins. Built to match the supplied site mockup: olive hero with portrait, cream book showcase, black "Word Up Story" feature band, and a connect/footer section.
Version: 2.2
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: tomi-jenkins
*/

/* ==========================================================================
   0. Custom properties / palette
   ========================================================================== */
:root{
  --olive-dark:   #232308;
  --olive-mid:    #4a4a1f;
  --olive-light:  #6f6e35;
  --gold:         #b6912f;
  --gold-bright:  #cda640;
  --gold-deep:    #6b5a1f;
  --cream:        #ece1cd;
  --cream-2:      #e3d5bb;
  --ink:          #1c1c1c;
  --black:        #0a0a0a;
  --white:        #f7f4ec;

  --font-display: 'Cinzel', 'Times New Roman', serif;
  --font-script:  'Cormorant Garamond', Georgia, serif;
  --font-body:    'EB Garamond', Georgia, 'Times New Roman', serif;
  --font-ui:      'EB Garamond', Georgia, serif;

  --maxw: 1180px;
}

/* ==========================================================================
   1. Reset / base
   ========================================================================== */
*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  font-size: 18px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ margin:0; font-weight:400; }
.screen-reader-text{ position:absolute; left:-9999px; }

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

/* Eyebrow / small caps label */
.eyebrow{
  font-family: var(--font-ui);
  letter-spacing: .28em;
  text-transform: uppercase;
  font-size: 14px;
  color: var(--gold-deep);
}

/* Divider flourish */
.flourish{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin: 18px 0 26px;
}
.flourish::before,
.flourish::after{
  content:"";
  width: 70px;
  height:1px;
  background: var(--gold);
  opacity:.6;
}
.flourish span{
  color: var(--gold);
  font-size: 13px;
  transform: rotate(45deg);
}

/* Buttons */
.btn{
  display:inline-block;
  font-family: var(--font-ui);
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size: 13px;
  padding: 14px 28px;
  border:1px solid var(--gold);
  transition: all .25s ease;
  cursor:pointer;
}
.btn-solid{
  background: var(--gold);
  color: var(--olive-dark);
  border-color: var(--gold);
}
.btn-solid:hover{
  background: var(--gold-bright);
  border-color: var(--gold-bright);
}
.btn-outline{
  background: transparent;
  color: var(--white);
  border-color: rgba(247,244,236,.55);
}
.btn-outline:hover{
  border-color: var(--white);
  background: rgba(255,255,255,.08);
}
.btn-outline-dark{
  background: transparent;
  color: var(--olive-dark);
  border-color: var(--olive-dark);
}
.btn-outline-dark:hover{
  background: var(--olive-dark);
  color: var(--white);
}

/* ==========================================================================
   1.5 Site header / nav
   ========================================================================== */
.site-header{
  background: var(--olive-dark);
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 2px 14px rgba(0,0,0,.25);
}
.site-header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height: 76px;
}
.site-brand{
  font-family: var(--font-display);
  font-size: 20px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color: var(--white);
}
.site-brand,
.custom-logo-link{
  display:flex;
  align-items:center;
}
.site-brand img,
.custom-logo-link img{
  max-height: 44px;
  width: auto;
  display:block;
}
.site-brand:hover{ color: var(--gold-bright); }

.nav-menu{
  display:flex;
  align-items:center;
  gap: 34px;
}
.nav-menu a{
  font-family: var(--font-ui);
  font-size: 13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color: rgba(247,244,236,.88);
}
.nav-menu a:hover{ color: var(--gold-bright); }
.nav-menu .current-menu-item > a{ color: var(--gold-bright); }

.nav-toggle{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width: 34px;
  height: 34px;
  background:none;
  border:none;
  cursor:pointer;
  padding:0;
}
.nav-toggle span{
  display:block;
  width:100%;
  height:2px;
  background: var(--white);
  transition: transform .2s ease, opacity .2s ease;
}
.nav-toggle.is-open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2){ opacity:0; }
.nav-toggle.is-open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }


.hero{
  position: relative;
  background:
    radial-gradient(ellipse at 62% 38%, var(--olive-light) 0%, var(--olive-mid) 48%, var(--olive-dark) 100%);
  color: var(--white);
  overflow:hidden;
  min-height: 720px;
}
.hero .wrap{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  min-height: 720px;
  padding-top: 56px;
  padding-bottom: 56px;
}
.hero-content{
  max-width: 480px;
}
.hero-name{
  font-family: var(--font-display);
  line-height: .92;
  margin: 18px 0 6px;
}
.hero-name .first{
  display:block;
  font-size: clamp(46px, 6vw, 74px);
  color: var(--white);
  letter-spacing: .02em;
}
.hero-name .last{
  display:block;
  font-size: clamp(50px, 6.6vw, 82px);
  color: var(--gold-bright);
  letter-spacing: .02em;
}
.hero-rule{
  width: 230px;
  height:1px;
  background: var(--gold);
  opacity:.7;
  margin: 14px 0 22px;
}
.hero-tagline{
  font-family: var(--font-script);
  font-size: 27px;
  margin-bottom: 22px;
}
.hero-tagline .line2{
  display:block;
  color: var(--gold-bright);
  font-style: italic;
}
.hero-copy{
  max-width: 430px;
  font-size: 17px;
  color: rgba(247,244,236,.92);
  margin-bottom: 30px;
}
.hero-ctas{ display:flex; gap:16px; flex-wrap:wrap; }

.hero-portrait{
  position:absolute;
  z-index:1;
  top:0;
  right:0;
  bottom:0;
  width: 60%;
  display:flex;
}
.hero-portrait img{
  width:100%;
  height:100%;
  object-fit: contain;
  object-position: bottom right;
  filter: drop-shadow(0 28px 38px rgba(0,0,0,.5));
}

/* ==========================================================================
   3. Books section
   ========================================================================== */
.books{
  background: var(--cream);
  padding: 80px 0 90px;
  text-align:center;
}
.books h2{
  font-family: var(--font-display);
  font-size: clamp(28px,3.4vw,38px);
  letter-spacing: .04em;
  color: var(--olive-dark);
}
.books .intro{
  max-width: 560px;
  margin: 0 auto 50px;
  color: #4d4a3c;
  font-size: 17px;
}
.book-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 250px));
  align-items: stretch;
  justify-content: center;
  gap: 40px 32px;
  max-width: 1116px;
  margin: 0 auto;
}
.book-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  height:100%;
}
.book-card img{
  margin: 0 auto 22px;
  height: 300px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  box-shadow: 0 18px 34px rgba(40,35,15,.28);
}
.book-card h3{
  font-family: var(--font-script);
  font-size: 24px;
  color: var(--olive-dark);
  margin-bottom: 8px;
}
.book-card p{
  font-size: 15px;
  color: #5a5644;
  margin: 0 0 18px;
  max-width: 240px;
}
.book-card .btn{ margin-top: auto; }

/* ==========================================================================
   4. Word Up Story band
   ========================================================================== */
.wordup{
  background: var(--black);
  color: var(--white);
  padding: 70px 0;
}
.wordup .wrap{
  display:grid;
  grid-template-columns: .8fr 1.6fr .9fr;
  align-items:center;
  gap: 40px;
}
.wordup-logo img{ max-width: 170px; margin: 0 auto; }
.wordup-text{
  font-family: var(--font-script);
  font-size: 24px;
  line-height: 1.45;
  color: var(--white);
}
.wordup-photo img{
  max-width: 230px;
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,.08);
}

/* ==========================================================================
   5. Connect / footer
   ========================================================================== */
.connect{
  background: var(--cream);
  padding: 70px 0 50px;
}
.connect .wrap{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 50px;
  align-items:center;
}
.connect h2{
  font-family: var(--font-display);
  font-size: clamp(24px,3vw,32px);
  color: var(--olive-dark);
  letter-spacing:.02em;
}
.connect .flourish{ justify-content:flex-start; }
.connect .flourish::before{ width:0; }
.connect p{
  color: #4d4a3c;
  max-width: 380px;
  margin-bottom: 26px;
}
.connect-links{ display:flex; flex-direction:column; gap: 18px; }
.connect-links li{
  display:flex;
  align-items:center;
  gap: 14px;
  font-size: 15px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.connect-links a{ display:flex; align-items:center; gap:14px; }
.connect-links a:hover{ color: var(--gold-deep); }
.connect-links i{
  width: 22px;
  text-align:center;
  color: var(--gold-deep);
  font-size: 18px;
}

.site-footer-bar{
  background: var(--olive-dark);
  color: rgba(247,244,236,.65);
  text-align:center;
  font-size: 13px;
  letter-spacing:.04em;
  padding: 18px 0;
}

/* ==========================================================================
   7. Generic pages + Gutenberg block support
   ========================================================================== */
.page-main{ padding-top: 70px; padding-bottom: 90px; }
.page-title{
  font-family: var(--font-display);
  color: var(--olive-dark);
  font-size: clamp(30px,4vw,42px);
  max-width: 760px;
  margin: 0 auto 32px;
  padding: 0 32px;
  text-align:center;
}

/* Wide/full alignment support for classic-theme block editing */
.entry-content > *{
  max-width: 760px;
  margin-left:auto;
  margin-right:auto;
  padding-left: 32px;
  padding-right: 32px;
}
.entry-content > .alignwide{
  max-width: 1100px;
}
.entry-content > .alignfull{
  max-width: none;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left:0;
  padding-right:0;
}
.entry-content > .alignfull > *{ padding-left:32px; padding-right:32px; }

/* Editor color palette -> usable utility classes on the front end */
.has-olive-dark-color{ color: var(--olive-dark) !important; }
.has-olive-mid-color{ color: var(--olive-mid) !important; }
.has-gold-color{ color: var(--gold) !important; }
.has-gold-bright-color{ color: var(--gold-bright) !important; }
.has-cream-color{ color: var(--cream) !important; }
.has-black-color{ color: var(--black) !important; }
.has-white-color{ color: var(--white) !important; }
.has-ink-color{ color: var(--ink) !important; }
.has-olive-dark-background-color{ background-color: var(--olive-dark) !important; }
.has-olive-mid-background-color{ background-color: var(--olive-mid) !important; }
.has-gold-background-color{ background-color: var(--gold) !important; }
.has-gold-bright-background-color{ background-color: var(--gold-bright) !important; }
.has-cream-background-color{ background-color: var(--cream) !important; }
.has-black-background-color{ background-color: var(--black) !important; }
.has-white-background-color{ background-color: var(--white) !important; }
.has-ink-background-color{ background-color: var(--ink) !important; }

/* Group block styles: pre-made backgrounds for full-width bands */
.wp-block-group.is-style-tj-olive-band{
  background: radial-gradient(ellipse at 50% 30%, var(--olive-light) 0%, var(--olive-mid) 45%, var(--olive-dark) 100%);
  color: var(--white);
  padding: 70px 32px;
}
.wp-block-group.is-style-tj-black-band{
  background: var(--black);
  color: var(--white);
  padding: 60px 32px;
}
.wp-block-group.is-style-tj-olive-band .wp-block-heading,
.wp-block-group.is-style-tj-black-band .wp-block-heading{ color: var(--white); }

/* Button block styles matching the site's existing .btn treatments */
.wp-block-button.is-style-tj-gold-solid .wp-block-button__link{
  background: var(--gold);
  color: var(--olive-dark);
  border: 1px solid var(--gold);
  border-radius: 0;
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 13px;
  padding: 14px 28px;
}
.wp-block-button.is-style-tj-gold-solid .wp-block-button__link:hover{
  background: var(--gold-bright);
  border-color: var(--gold-bright);
}
.wp-block-button.is-style-tj-outline-light .wp-block-button__link{
  background: transparent;
  color: var(--white);
  border: 1px solid rgba(247,244,236,.55);
  border-radius: 0;
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 13px;
  padding: 14px 28px;
}
.wp-block-button.is-style-tj-outline-light .wp-block-button__link:hover{
  border-color: var(--white);
  background: rgba(255,255,255,.08);
}
.wp-block-button.is-style-tj-outline-dark .wp-block-button__link{
  background: transparent;
  color: var(--olive-dark);
  border: 1px solid var(--olive-dark);
  border-radius: 0;
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 13px;
  padding: 14px 28px;
}
.wp-block-button.is-style-tj-outline-dark .wp-block-button__link:hover{
  background: var(--olive-dark);
  color: var(--white);
}

@media (max-width: 700px){
  .entry-content > .alignfull > .wp-block-columns{ flex-wrap:wrap; }
}

/* ==========================================================================
   8. Responsive
   ========================================================================== */
@media (max-width: 900px){
  .nav-toggle{ display:flex; }
  .nav-menu{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    background: var(--olive-dark);
    max-height:0;
    overflow:hidden;
    transition: max-height .25s ease;
  }
  .nav-menu.is-open{ max-height: 320px; }
  .nav-menu li{ width:100%; }
  .nav-menu a{
    display:block;
    width:100%;
    padding: 14px 32px;
    border-top: 1px solid rgba(247,244,236,.1);
  }
  .site-header{ position:relative; }

  .hero{ min-height:auto; }
  .hero .wrap{ display:block; text-align:center; min-height:auto; padding-top:0; padding-bottom:36px; }
  .hero-content{ max-width:none; padding:0 4px; }
  .hero-rule{ margin-inline:auto; }
  .hero-copy{ margin-inline:auto; }
  .hero-ctas{ justify-content:center; }
  .hero-portrait{
    position:static;
    width:100%;
    height:300px;
    margin-bottom: 8px;
  }
  .hero-portrait img{ object-position:bottom center; }

  .book-grid{ grid-template-columns:1fr; max-width:320px; gap:54px; }

  .wordup .wrap{ grid-template-columns:1fr; text-align:center; }
  .wordup-text{ order:-1; }

  .connect .wrap{ grid-template-columns:1fr; text-align:center; }
  .connect .flourish{ justify-content:center; }
  .connect p{ margin-inline:auto; }
  .connect-links{ align-items:center; }
}

@media (max-width: 480px){
  body{ font-size:16px; }
  .hero-name .first{ font-size:42px; }
  .hero-name .last{ font-size:46px; }
}
