:root{
  --jp-bg:#fbfaf7;
  --jp-soft:#f1f0ec;
  --jp-black:#111111;
  --jp-gray:#646464;
  --jp-line:#d8d5ce;
  --jp-white:#ffffff;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--jp-bg);
  color:var(--jp-black);
  font-family: Georgia, 'Times New Roman', serif;
}

.jp-navbar{
  background:rgba(251,250,247,.94);
  backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:.25s ease;
}
.jp-navbar.scrolled{border-bottom-color:var(--jp-line); box-shadow:0 8px 30px rgba(0,0,0,.04)}
.logo-img{width:82px;height:82px;object-fit:contain}
.nav-link{
  color:var(--jp-black);
  font-size:15px;
  padding:12px 10px!important;
}
.nav-link:hover{color:#777}

.hero-section{overflow:hidden;border-bottom:1px solid var(--jp-line)}
.hero-content{padding-left:6vw;padding-top:80px}
.hero-title{
  font-size:clamp(4.2rem,9vw,8.5rem);
  line-height:.9;
  letter-spacing:-.06em;
  margin-bottom:22px;
}
.title-line{width:54px;height:1px;background:var(--jp-black);margin:0 0 24px 205px}
.hero-kicker{
  font-size:18px;
  letter-spacing:.32em;
  margin-bottom:30px;
}
.hero-text{
  font-size:20px;
  line-height:1.65;
  max-width:560px;
}
.hero-photo-wrap{min-height:650px;display:flex;align-items:flex-end;justify-content:center}
.hero-photo{
  width:100%;
  max-height:760px;
  object-fit:cover;
  object-position:center;
}

.btn-jp-dark,.btn-jp-outline{
  border-radius:0;
  min-width:150px;
  padding:14px 26px;
  font-weight:700;
  font-size:15px;
  font-family:Georgia,'Times New Roman',serif;
}
.btn-jp-dark{background:#000;color:#fff;border:1px solid #000}
.btn-jp-dark:hover{background:#333;color:#fff}
.btn-jp-outline{border:1px solid #111;color:#111;background:transparent}
.btn-jp-outline:hover{background:#111;color:#fff}

.quote-section{padding:28px 0 22px;background:#fff;border-bottom:1px solid var(--jp-line)}
.quote-mark{font-size:42px;line-height:1;font-weight:bold}
.quote-section p{font-size:24px;margin:0 0 10px}
.quote-section .title-line{margin:0 auto;width:58px}

.section-label,.book-category,.book-type,.sales-subtitle,.simple-link{
  font-family:Arial,sans-serif;
}
.section-label{display:inline-block;text-transform:uppercase;letter-spacing:.18em;color:var(--jp-gray);font-size:13px;margin-bottom:14px}
.section-title{font-size:clamp(2.4rem,4vw,4.4rem);line-height:1;letter-spacing:-.04em}
.bio-text{font-size:21px;line-height:1.75;color:#222}

.books-section{background:#fff;border-bottom:1px solid var(--jp-line)}
.simple-link{color:#111;text-decoration:none;font-size:15px}
.simple-link:hover{text-decoration:underline}
.book-category{font-size:15px;color:#222}
.book-card{display:grid;grid-template-columns:132px 1fr;gap:28px;align-items:center;padding-right:28px;border-right:1px solid var(--jp-line);min-height:260px}
.book-cover{
  width:132px;height:220px;padding:24px 18px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 16px 26px rgba(0,0,0,.16)
}
.book-cover span{font-size:21px;line-height:1.05}
.book-cover small{font-size:11px}
.cover-dark{background:#15110e;color:#fff}
.cover-light{background:#eee9df;color:#8c261e}
.cover-gray{background:#d8d2c8;color:#111}
.book-info h3{font-size:25px;line-height:1.1;margin-bottom:12px}
.book-info p{font-size:16px;line-height:1.5;margin-bottom:12px}
.book-type{font-size:13px;color:var(--jp-gray);margin-bottom:10px!important}
.book-info a{color:#111;text-decoration:none}
.book-info a:hover{text-decoration:underline}

.notes-section{background:#eee;border-bottom:1px solid var(--jp-line)}
.notes-content{padding:70px 7vw;background:#eee}
.notes-content h2{font-size:38px;margin-bottom:18px}
.notes-content p{font-size:18px;line-height:1.6;max-width:420px;margin-bottom:30px}
.notes-image{min-height:300px;background:linear-gradient(rgba(0,0,0,.18),rgba(0,0,0,.18)),url('../img/JP-cv.jpg') center/cover;filter:grayscale(100%)}

.sales-section{background:var(--jp-bg);border-bottom:1px solid var(--jp-line)}
.sales-subtitle{font-size:17px;color:#222}
.sale-card{border:1px solid #a9a6a0;background:#fbfaf7;padding:26px;min-height:210px;height:100%;transition:.25s ease}
.sale-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.08)}
.sale-card h3{font-size:18px;margin-bottom:18px;display:flex;gap:8px;align-items:center}
.sale-card p{font-size:15px;line-height:1.55;margin-bottom:14px}
.sale-card i{font-size:24px}

.footer-section{background:#111;color:#fff;padding:45px 0}
.footer-section h3{font-size:20px;margin-bottom:18px}
.footer-section p{margin-bottom:9px;font-family:Arial,sans-serif;font-size:14px}
.footer-section a{color:#fff;text-decoration:none}
.footer-section a:hover{text-decoration:underline}
.footer-logo{width:90px;height:90px;object-fit:contain;filter:invert(1) grayscale(1)}
.copyright{font-size:12px!important;margin-top:12px;color:#ddd}

@media(max-width:991px){
  .logo-img{width:64px;height:64px}
  .hero-content{padding:110px 20px 30px}
  .hero-photo-wrap{min-height:auto;padding:110px 20px 0}
  .hero-photo{border-radius:0;max-height:420px}
  .title-line{margin-left:0}
  .hero-kicker{font-size:14px;letter-spacing:.18em}
  .book-card{border-right:0;border-bottom:1px solid var(--jp-line);padding-bottom:28px}
}
@media(max-width:575px){
  .book-card{grid-template-columns:1fr}
  .book-cover{width:150px;height:230px}
  .hero-title{font-size:4rem}
  .quote-section p{font-size:20px}
}
