/* ============================================================
   BookArt — Global Stylesheet v2.0
   Brand: DM Sans · Ink #141414 · Cream #F0EBE3 · Teal #0E7C86
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#141414;
  --cream:#F0EBE3;
  --warm:#E8E0D5;
  --teal:#0E7C86;
  --teal-dark:#0A6670;
  --teal-light:#E0F2F3;
  --sand:#C9B99A;
  --mist:rgba(20,20,20,0.5);
  --border:rgba(20,20,20,0.1);
  --white:#FFFFFF;
  --sans:'DM Sans',system-ui,sans-serif;
}

html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);overflow-x:hidden}

/* ── ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 5%;
  background:rgba(20,20,20,0.95);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.logo{font-size:1.6rem;font-weight:600;color:var(--cream);text-decoration:none}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{
  font-size:.82rem;font-weight:400;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(240,235,227,0.6);text-decoration:none;transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--cream)}
.nav-btn{
  background:var(--teal)!important;color:#fff!important;
  padding:.55rem 1.4rem!important;border-radius:2px!important;
  font-weight:500!important;font-size:.8rem!important;letter-spacing:.06em!important;
  text-transform:uppercase!important;transition:background .2s!important;
}
.nav-btn:hover{background:var(--teal-dark)!important}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--cream);transition:.3s}
.mobile-menu{display:none}

/* ── BUTTONS ── */
.btn-primary{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--teal);color:#fff;
  padding:.85rem 2rem;border-radius:2px;
  font-weight:500;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;
  text-decoration:none;transition:background .2s,transform .15s;
}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-1px)}
.btn-ghost{
  font-size:.85rem;font-weight:400;letter-spacing:.04em;
  color:var(--ink);text-decoration:none;
  border-bottom:1px solid var(--border);padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.btn-ghost:hover{color:var(--teal);border-color:var(--teal)}
.btn-white{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--teal);color:#fff;
  padding:.9rem 2.5rem;font-weight:500;
  font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;
  text-decoration:none;transition:background .2s;
}
.btn-white:hover{background:var(--teal-dark)}

/* ── TYPOGRAPHY HELPERS ── */
.section-eyebrow{
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal);margin-bottom:1rem;display:block;
}
.section-title{
  font-size:clamp(2.2rem,4vw,3.5rem);
  line-height:1.1;letter-spacing:-.01em;margin-bottom:.75rem;
  font-weight:300;
}
.section-sub{
  font-size:.95rem;color:var(--mist);line-height:1.8;
  max-width:500px;font-weight:300;margin-bottom:4rem;
}

/* ── HERO ── */
.hero-section{background:var(--ink)}
.hero{
  min-height:100vh;
  display:grid;grid-template-columns:1fr 1fr;
  padding:8rem 5% 4rem;
  gap:5rem;max-width:1300px;margin:0 auto;
  align-items:center;
}
.hero-tag{
  display:inline-block;font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--sand);margin-bottom:1.5rem;
  border-bottom:1px solid var(--sand);padding-bottom:4px;
}
.hero-title{
  font-size:clamp(3rem,5.5vw,5rem);font-weight:300;
  line-height:1.05;letter-spacing:-0.01em;margin-bottom:1.5rem;
  color:var(--cream);
}
.hero-title em{font-style:italic;color:var(--teal)}
.hero-sub{
  font-size:1rem;color:rgba(240,235,227,0.7);line-height:1.8;
  margin-bottom:2.5rem;font-weight:300;max-width:440px;
}
.hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-img{width:100%;aspect-ratio:4/5;background:var(--warm);overflow:hidden;position:relative}
.hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.hero-float{
  position:absolute;bottom:2rem;left:-2rem;
  background:var(--ink);border:1px solid rgba(255,255,255,0.1);
  padding:1rem 1.25rem;display:flex;align-items:center;gap:.75rem;
  box-shadow:0 8px 32px rgba(0,0,0,0.3);
}
.float-dot{width:36px;height:36px;background:var(--teal);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff}
.float-txt strong{display:block;font-size:.82rem;font-weight:500;color:var(--cream)}
.float-txt span{font-size:.72rem;color:rgba(240,235,227,0.6)}

/* ── TICKER ── */
.ticker-wrap{border-top:1px solid rgba(255,255,255,0.06);border-bottom:1px solid var(--border);background:var(--ink);overflow:hidden;padding:.8rem 0}
.ticker{display:flex;gap:3rem;animation:ticker 28s linear infinite;white-space:nowrap}
.ticker-item{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);opacity:.7;flex-shrink:0}
.ticker-item span{color:var(--teal);margin-right:3rem}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── STATS ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border)}
.stat{padding:2.5rem 2rem;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-n{font-size:3rem;font-weight:300;color:var(--ink);line-height:1;display:block;margin-bottom:.35rem}
.stat-l{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mist)}

/* ── HOW IT WORKS ── */
.how{max-width:1300px;margin:0 auto;padding:3rem 5%}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;background:var(--border)}
.step{background:var(--cream);padding:2.5rem 2rem;transition:background .25s}
.step:hover{background:var(--white)}
.step-n{font-size:4rem;font-weight:300;color:var(--teal);line-height:1;margin-bottom:1.25rem;display:block;opacity:.2}
.step-title{font-size:1rem;font-weight:500;margin-bottom:.5rem}
.step-desc{font-size:.88rem;color:var(--mist);line-height:1.7}

/* ── BOOK CARDS ── */
.book-card{background:var(--white);transition:background .25s;overflow:hidden;display:flex;flex-direction:column;border:1px solid #E0D8CC}
.book-card:hover{background:#FAFAFA}
.book-card[data-hidden="true"]{display:none}
.book-img{aspect-ratio:3/4;overflow:hidden;background:var(--warm);display:flex;align-items:center;justify-content:center}
.book-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.book-card:hover .book-img img{transform:scale(1.03)}
.book-img-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:.5rem}
.book-img-ph span{font-size:3rem;opacity:.4}
.book-img-ph p{font-size:.7rem;color:var(--mist);font-style:italic;padding:0 1rem;text-align:center}
.book-info{padding:1.5rem}
.book-tag{display:inline-block;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);border:1px solid currentColor;padding:.2rem .6rem;margin-bottom:.6rem}
.book-name{font-size:1.4rem;font-weight:500;margin-bottom:.35rem;line-height:1.1}
.book-desc{font-size:.82rem;color:var(--mist);line-height:1.6;margin-bottom:.75rem}
.book-occasion{font-size:.75rem;color:var(--mist);font-style:italic;margin-bottom:1.25rem}
.book-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--border)}
.book-price{font-weight:600;font-size:.95rem;color:var(--teal)}
.book-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--teal);padding:.45rem 1rem;text-decoration:none;transition:background .2s}
.book-btn:hover{background:var(--teal-dark)}

/* ── START HERE ── */
.start-here{background:var(--cream);padding:4rem 5%;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.start-here-inner{max-width:1300px;margin:0 auto}
.start-here-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:2rem;max-width:900px;margin-left:auto;margin-right:auto}
.start-here-tag{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--teal);padding:.25rem .75rem;display:inline-block;margin-bottom:.6rem}

/* ── REVIEWS / CAROUSEL ── */
.reviews{padding:4rem 5%;border-bottom:1px solid var(--border)}
.reviews-inner{max-width:900px;margin:0 auto}
.carousel{position:relative;margin-top:2rem;overflow:hidden}
.carousel-track{display:flex;transition:transform .4s ease}
.carousel-slide{min-width:100%;flex-shrink:0;width:100%}
.review-img{width:100%;border:1px solid var(--border);display:block;border-radius:4px;height:auto;object-fit:contain;background:#fff}
.carousel-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.25rem}
.carousel-btn{background:none;border:1px solid var(--border);width:36px;height:36px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:var(--sans)}
.carousel-btn:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.carousel-dots{display:flex;gap:.5rem}
.carousel-dot{width:6px;height:6px;border-radius:50%;background:var(--border);border:none;cursor:pointer;padding:0;transition:background .2s}
.carousel-dot.active{background:var(--teal)}

/* ── COLLECTION ── */
.collection{max-width:1300px;margin:0 auto;padding:7rem 5%}
.collection-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem;flex-wrap:wrap;gap:1rem}
.books-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.collection-cta{text-align:center;margin-top:3rem}

/* ── VIDEO SECTION ── */
.video-section{background:var(--ink);padding:7rem 5%;text-align:center}
.video-section .section-eyebrow{color:var(--teal)}
.video-section .section-title{color:var(--cream);margin-bottom:.75rem}
.video-section .section-sub{color:rgba(240,235,227,0.6);margin:0 auto 3rem;max-width:480px}
.video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:900px;margin:0 auto}
.video-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);overflow:hidden}
.video-embed{aspect-ratio:9/16;width:100%;overflow:hidden}
.video-embed iframe{width:100%;height:100%;border:none}
.video-label{padding:.75rem 1rem;text-align:left}
.video-label span{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(240,235,227,0.4)}

/* ── QUOTE ── */
.quote-section{padding:6rem 5%;text-align:center;border-top:1px solid var(--border);border-bottom:1px solid var(--border);max-width:1300px;margin:0 auto}
blockquote{font-size:clamp(1.6rem,3vw,2.5rem);font-weight:300;font-style:italic;line-height:1.4;color:var(--ink);max-width:750px;margin:0 auto 1.5rem}
blockquote::before{content:'\201C';color:var(--teal);font-size:1.2em;margin-right:.1em}
blockquote::after{content:'\201D';color:var(--teal);font-size:1.2em;margin-left:.1em}
cite{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mist)}

/* ── BLOG PREVIEW ── */
.blog-section{background:var(--warm);padding:7rem 5%}
.blog-inner{max-width:1300px;margin:0 auto}
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:3rem}
.blog-card{background:var(--white);padding:2.5rem;border:1px solid #E0D8CC;text-decoration:none;color:inherit;display:block;transition:border-color .2s,background .2s}
.blog-card:hover{border-color:var(--teal);background:#FAFAFA}
.blog-card-tag{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:.75rem;display:block}
.blog-card-title{font-size:1.6rem;font-weight:500;line-height:1.2;margin-bottom:.75rem}
.blog-card-excerpt{font-size:.85rem;color:var(--mist);line-height:1.7;margin-bottom:1.25rem}
.blog-card-read{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--border);display:inline-block;padding-bottom:2px}

/* ── FOOTER CTA ── */
.footer-cta{background:var(--ink);color:#fff;padding:6rem 5%;text-align:center}
.footer-cta .section-eyebrow{color:var(--sand)}
.footer-cta .section-title{color:#fff;margin-bottom:.75rem}
.footer-cta p{color:rgba(240,235,227,0.6);font-size:.95rem;margin-bottom:2.5rem;font-weight:300}

/* ── FOOTER ── */
footer{background:var(--ink);padding:3rem 5%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem}
.footer-logo{font-size:1.4rem;color:var(--cream);font-weight:500;text-decoration:none}
footer p{font-size:.75rem;color:rgba(255,255,255,.3)}
.footer-links{display:flex;gap:2rem}
.footer-links a{font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.3);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--cream)}

/* ── COLLECTION PAGE ── */
.page-header{padding:10rem 5% 5rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:2rem}
.page-title{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:300;line-height:1.05;letter-spacing:-.01em}
.page-sub{font-size:.95rem;color:var(--mist);line-height:1.8;font-weight:300;max-width:380px}
.filter-bar{padding:1.5rem 5%;border-bottom:1px solid var(--border);display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}
.filter-label{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);margin-right:.5rem}
.filter-btn{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.4rem 1rem;border:1px solid var(--border);background:none;cursor:pointer;color:var(--mist);transition:all .2s;font-family:var(--sans)}
.filter-btn:hover,.filter-btn.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.collection-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.empty-state{grid-column:1/-1;text-align:center;padding:6rem 2rem;display:none}
.empty-state.visible{display:block}
.empty-state p{color:var(--mist);font-size:.9rem}
.bottom-cta{text-align:center;padding:5rem 5%;border-top:1px solid var(--border)}
.bottom-cta p{font-size:.95rem;color:var(--mist);margin-bottom:1.5rem;font-weight:300}

/* ── BLOG PAGE ── */
.featured{max-width:1300px;margin:0 auto;padding:4rem 5%;border-bottom:1px solid var(--border)}
.featured-label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mist);margin-bottom:2rem;display:block}
.featured-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.featured-img{aspect-ratio:4/3;background:var(--warm);overflow:hidden;display:flex;align-items:center;justify-content:center}
.featured-img img{width:100%;height:100%;object-fit:cover}
.featured-tag{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);border:1px solid currentColor;padding:.2rem .6rem;display:inline-block;margin-bottom:1rem}
.featured-title{font-size:clamp(1.8rem,3vw,2.8rem);font-weight:500;line-height:1.1;margin-bottom:1rem}
.featured-excerpt{font-size:.9rem;color:var(--mist);line-height:1.8;margin-bottom:1.5rem;font-weight:300}
.featured-meta{font-size:.75rem;color:var(--mist);margin-bottom:1.5rem;letter-spacing:.04em}
.posts-section{max-width:1300px;margin:0 auto;padding:4rem 5%}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.post-card{text-decoration:none;color:inherit;display:block;border-bottom:1px solid var(--border);padding-bottom:2rem;transition:border-color .2s}
.post-card:hover{border-color:var(--teal)}
.post-tag{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:.6rem;display:block}
.post-title{font-size:1.35rem;font-weight:500;line-height:1.2;margin-bottom:.5rem}
.post-excerpt{font-size:.82rem;color:var(--mist);line-height:1.65;margin-bottom:.75rem}
.post-read{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}

/* ── ARTICLE ── */
.article-header{max-width:780px;margin:0 auto;padding:9rem 5% 3rem;border-bottom:1px solid var(--border)}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mist);margin-bottom:2rem}
.breadcrumb a{color:var(--mist);text-decoration:none}
.breadcrumb a:hover{color:var(--teal)}
.breadcrumb span{opacity:.4}
.article-tag{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);border:1px solid currentColor;padding:.2rem .6rem;display:inline-block;margin-bottom:1.25rem}
.article-title{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;line-height:1.08;margin-bottom:1rem;letter-spacing:-.01em}
.article-meta{font-size:.78rem;color:var(--mist);letter-spacing:.04em;margin-bottom:1.5rem}
.article-lead{font-size:1.15rem;color:var(--ink);line-height:1.75;font-weight:300}
.article-body{max-width:680px;margin:0 auto;padding:3.5rem 5% 5rem}
.article-body p{font-size:1rem;line-height:1.85;color:var(--ink);margin-bottom:1.5rem;font-weight:300;opacity:.85}
.article-body h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:500;line-height:1.2;margin:3rem 0 1rem;color:var(--ink)}
.article-body h3{font-size:1.3rem;font-weight:500;margin:2rem 0 .75rem;color:var(--ink)}
.highlight{border-left:2px solid var(--teal);padding:1.25rem 1.5rem;margin:2.5rem 0;background:var(--teal-light);font-style:italic;font-size:1.1rem;line-height:1.55;color:var(--ink)}
.article-cta{margin:3.5rem 0;background:var(--ink);padding:2.5rem;text-align:center}
.article-cta p{color:rgba(255,255,255,.65);font-size:.9rem;margin-bottom:1.25rem;line-height:1.6}
.article-cta strong{display:block;font-size:1.6rem;font-weight:500;color:#fff;margin-bottom:.5rem}
.btn-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--teal);color:#fff;padding:.8rem 1.8rem;font-weight:500;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:background .2s}
.btn-cta:hover{background:var(--teal-dark)}
.article-faq{margin:3rem 0}
.faq-item{border-bottom:1px solid var(--border);padding:1.25rem 0}
.faq-q{font-weight:500;font-size:.95rem;margin-bottom:.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q::after{content:'+';font-size:1.2rem;color:var(--mist);transition:transform .2s;flex-shrink:0}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{font-size:.88rem;color:var(--mist);line-height:1.7;display:none;padding-top:.5rem}
.faq-item.open .faq-a{display:block}
.related{background:var(--warm);padding:5rem 5%;border-top:1px solid var(--border)}
.related-inner{max-width:1100px;margin:0 auto}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.related-card{background:var(--cream);padding:1.75rem;text-decoration:none;color:inherit;border:1px solid var(--border);transition:border-color .2s}
.related-card:hover{border-color:var(--teal)}
.related-tag{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:.5rem;display:block}
.related-title{font-size:1.2rem;font-weight:500;line-height:1.2;margin-bottom:.5rem}
.related-read{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mist)}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .mobile-menu{display:block;position:fixed;inset:0;background:var(--ink);z-index:200;padding:6rem 2rem 3rem;transform:translateX(100%);transition:transform .35s ease}
  .mobile-menu.open{transform:translateX(0)}
  .mobile-menu ul{list-style:none;display:flex;flex-direction:column;gap:1.5rem}
  .mobile-menu a{font-size:2rem;font-weight:300;color:var(--cream);text-decoration:none}
  .mobile-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--cream)}
  .hero{grid-template-columns:1fr;padding:7rem 5% 4rem;gap:2.5rem}
  .hero-visual{order:-1}
  .hero-float{left:0;bottom:1rem}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat{border-right:none;border-bottom:1px solid var(--border)}
  .stat:nth-child(2n){border-right:none}
  .stat:last-child,.stat:nth-last-child(2){border-bottom:none}
  .steps{grid-template-columns:1fr}
  .video-grid{grid-template-columns:1fr}
  .books-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr}
  .collection-grid{grid-template-columns:repeat(2,1fr)}
  .page-header{padding:8rem 5% 3rem}
  .featured-grid{grid-template-columns:1fr}
  .posts-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
  .article-header,.article-body{padding-left:1.5rem;padding-right:1.5rem}
  .start-here-grid{grid-template-columns:1fr;max-width:100%}
}
@media(max-width:580px){
  .books-grid{grid-template-columns:1fr}
  .collection-grid{grid-template-columns:1fr}
  .hero-title{font-size:2.6rem}
  .stats{grid-template-columns:repeat(2,1fr)}
}
