/* ============================================================
   MISSION 515 — shared stylesheet for all pages
   (the-book.html, trailer.html, reviews.html, about.html)
   ============================================================ */

/* ---------- DESIGN TOKENS ---------- */
:root{
  --bg:#070a12; --bg-2:#0b101b; --bg-3:#0e1422;
  --card:#111827; --card-2:#0d1320;
  --line:rgba(255,255,255,.08); --line-strong:rgba(255,255,255,.14);
  --orange:#f2701c; --orange-bright:#ff8a3d; --amazon:#f3851c;
  --text:#c5cdda; --text-dim:#8a94a6; --text-faint:#5e687a;
  --maxw:1180px;
}

.chrome{
  background:linear-gradient(180deg,#fff 0%,#e7ebf2 28%,#aab3c4 55%,#7e8799 78%,#cfd6e2 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Inter',system-ui,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.eyebrow{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.34em;font-weight:600;font-size:.78rem;color:var(--text-dim)}

/* ============================================================
   IMAGE SLOTS
   To set an image: just change the file name in
   style="background-image:url('images/imageN.jpg')"
   The grey "IMAGE N" label is only a guide while you build.
   >>> WHEN FINISHED: remove the /* */ around the rule at the
       very bottom of this file to hide ALL labels at once. <<<
   ============================================================ */
.imgslot{
  background-size:cover;background-position:center;background-repeat:no-repeat;
  background-color:#0b1018;   /* dark fallback so empty slots look intentional */
  position:relative;
}
.imgslot[data-label]::after{
  content:attr(data-label);
  position:absolute;left:10px;top:10px;
  font-family:'Saira',sans-serif;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.55);background:rgba(0,0,0,.5);padding:4px 8px;border-radius:4px;
  pointer-events:none;
}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:'Saira',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:.92rem;padding:.95em 1.6em;border-radius:8px;cursor:pointer;border:1px solid transparent;transition:transform .18s ease,box-shadow .25s ease,background .25s ease,border-color .25s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn svg{width:1.2em;height:1.2em;flex:none}
.btn-amazon{background:var(--amazon);color:#1a1206;box-shadow:0 8px 30px rgba(242,112,28,.32)}
.btn-amazon:hover{background:var(--orange-bright);box-shadow:0 12px 38px rgba(242,112,28,.45)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--orange);color:#fff}
.btn-outline-orange{background:transparent;color:#fff;border-color:rgba(242,112,28,.55)}
.btn-outline-orange:hover{border-color:var(--orange);box-shadow:0 0 0 1px var(--orange) inset}
.btn-dark{background:#11161f;color:#fff;border-color:var(--line-strong)}
.btn-dark:hover{border-color:var(--orange)}

/* ---------- HEADER / NAV ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(7,10,18,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:'Saira',sans-serif;font-weight:600;font-size:1.45rem;letter-spacing:.42em;color:#eef1f6}
.brand b{color:var(--orange);font-weight:700;letter-spacing:.12em}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.18em;font-size:.82rem;font-weight:500;color:var(--text-dim);padding:6px 0;position:relative;transition:color .2s ease}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:#fff}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--orange)}
.nav-buy{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;font-weight:600;color:var(--orange);border:1px solid var(--orange);border-radius:6px;padding:.55em 1.1em;transition:background .2s ease,color .2s ease}
.nav-buy:hover{background:var(--orange);color:#120a04}
.nav-toggle{display:none;background:none;border:0;color:#fff;cursor:pointer}
.nav-toggle svg{width:28px;height:28px}

/* ---------- HERO (shared) ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;min-height:540px}
.hero-copy{padding:78px 0;max-width:560px;position:relative;z-index:3}
.hero-copy .eyebrow{display:block;line-height:1.7}
.hero h1{font-family:'Saira',sans-serif;font-weight:800;font-size:clamp(2.6rem,6.5vw,5rem);line-height:.96;letter-spacing:.02em;text-transform:uppercase;margin:.3em 0 .25em}
.hero .tagline{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.16em;color:var(--orange);font-weight:600;font-size:clamp(.95rem,1.6vw,1.18rem);margin-bottom:1.1em}
.hero .lede{font-size:1.12rem;color:var(--text);margin-bottom:1.7em}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-quote{margin-top:22px;color:var(--text-dim);font-style:italic;font-size:.98rem}
.hero-quote b{color:var(--text);font-style:normal;font-weight:600;display:block;margin-top:4px}

/* hero artwork — reuses your existing image (contain, like you set on the home page) */
.hero-art{position:absolute;top:0;right:0;width:54%;height:100%;background:url('images/hero-chess.jpg') center/contain no-repeat #070a12}
.hero::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(90deg,var(--bg) 30%,transparent 72%)}

/* hero star rating (reviews) */
.hero-rating{display:flex;align-items:center;gap:14px;margin:.4em 0 1.3em}
.hero-rating .stars{color:var(--orange);letter-spacing:4px;font-size:1.6rem}
.hero-rating .out{font-family:'Saira',sans-serif;letter-spacing:.14em;color:var(--text-dim);font-size:.95rem;text-transform:uppercase}

/* ---------- SECTION + DIVIDER ---------- */
.section{padding:82px 0}
.section.alt{background:var(--bg-2)}
.sec-head{text-align:center;margin-bottom:46px}
.sec-head .label{display:inline-flex;align-items:center;gap:18px;font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.3em;font-weight:600;font-size:1.12rem;color:#eef1f6}
.sec-head .label::before,.sec-head .label::after{content:"";width:46px;height:1px;background:var(--orange)}
.sec-head p{color:var(--text-dim);margin-top:14px}

/* ---------- GENERIC SPLIT (image + text) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.img-right .text{order:1}.split.img-right .media{order:2}
.split .media{aspect-ratio:16/11;border-radius:12px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px var(--line)}
.block-head{font-family:'Saira',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:1.05rem;color:#eef1f6;margin-bottom:22px;display:flex;align-items:center;gap:16px}
.block-head::before{content:"";width:34px;height:2px;background:var(--orange);flex:none}
.split p{margin-bottom:1em;color:var(--text)}
.punch{color:var(--orange);font-weight:600}

/* ---------- BOOK COVER (reuses your existing book-cover.jpg) ---------- */
.book-cover{aspect-ratio:3/4;border-radius:6px;position:relative;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.6),0 0 0 1px var(--line);background:url('images/book-cover.jpg') center/contain no-repeat #070a12}

/* about-the-book grid (cover + text) */
.about{display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:center}

/* ---------- FEATURE PILLS / ICON LISTS ---------- */
.feature-pills{display:flex;gap:34px;flex-wrap:wrap;margin-top:26px}
.pill{display:flex;align-items:center;gap:12px;color:var(--text-dim);font-size:.92rem}
.pill .ic{width:42px;height:42px;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;color:var(--orange);flex:none}
.pill .ic svg{width:20px;height:20px}

.icon-list{display:flex;flex-direction:column;gap:26px}
.icon-list .row{display:flex;gap:18px;align-items:flex-start}
.icon-list .ic{width:44px;height:44px;flex:none;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;color:var(--orange)}
.icon-list .ic svg{width:22px;height:22px}
.icon-list h4{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.92rem;color:#eef1f6;margin-bottom:4px}
.icon-list p{color:var(--text-dim);font-size:.95rem;margin:0}

/* ---------- CARD GRIDS ---------- */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cards-5{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}

/* mini info card (icon, title, desc) */
.mini{background:var(--card-2);border:1px solid var(--line);border-radius:12px;padding:30px 24px;transition:transform .2s ease,border-color .2s ease}
.mini:hover{transform:translateY(-4px);border-color:rgba(242,112,28,.4)}
.mini .ic{width:46px;height:46px;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;color:var(--orange);margin-bottom:18px}
.mini .ic svg{width:24px;height:24px}
.mini h3{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:1rem;color:#eef1f6;margin-bottom:10px}
.mini p{color:var(--text-dim);font-size:.94rem}
.mini.center{text-align:center}.mini.center .ic{margin-left:auto;margin-right:auto}

/* ---------- REVIEW CARDS ---------- */
.review{background:var(--card-2);border:1px solid var(--line);border-radius:12px;padding:30px 26px;position:relative;transition:transform .2s ease,border-color .2s ease}
.review:hover{transform:translateY(-4px);border-color:rgba(242,112,28,.4)}
.stars{color:var(--orange);letter-spacing:3px;font-size:1.1rem;margin-bottom:16px}
.review blockquote{color:#dfe5ee;font-size:1rem;line-height:1.55}
.review cite{display:block;margin-top:16px;color:var(--text-dim);font-style:normal;font-size:.9rem}
.review .tag{display:block;margin-top:8px;font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--orange)}
.review .qmark{position:absolute;right:20px;bottom:12px;font-family:'Saira';font-size:3rem;color:rgba(242,112,28,.18);line-height:1}

/* ---------- THUMB GRID (visual universe) ---------- */
.thumb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.thumb figure{margin:0}
.thumb .media{aspect-ratio:4/3;border-radius:10px;overflow:hidden;border:1px solid var(--line);transition:border-color .2s ease,transform .2s ease}
.thumb:hover .media{border-color:rgba(242,112,28,.45);transform:translateY(-3px)}
.thumb figcaption{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--text-dim);text-align:center;margin-top:14px}

/* ---------- TEASER CLIPS ---------- */
.teaser-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.teaser .media{position:relative;aspect-ratio:16/10;border-radius:10px;overflow:hidden;border:1px solid var(--line);display:grid;place-items:center}
.teaser .dur{position:absolute;right:8px;bottom:8px;background:rgba(0,0,0,.7);color:#fff;font-size:.72rem;padding:2px 7px;border-radius:4px;font-family:'Saira'}
.teaser figcaption{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--text-dim);margin-top:12px}

/* ---------- PLAY BUTTON / VIDEO ---------- */
.play-btn{width:72px;height:72px;border-radius:50%;border:2px solid var(--orange);background:rgba(7,10,18,.55);display:grid;place-items:center;color:#fff;cursor:pointer;position:relative;z-index:2;transition:transform .2s ease,background .2s ease}
.play-btn:hover{transform:scale(1.07);background:rgba(242,112,28,.25)}
.play-btn svg{width:28px;height:28px;margin-left:3px}
.play-btn.sm{width:52px;height:52px}.play-btn.sm svg{width:20px;height:20px}
.video-frame{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);aspect-ratio:21/9;display:flex;align-items:center;justify-content:center}
.video-frame .overlay-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,7vw,90px);pointer-events:none}
.video-frame .overlay-text span{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.22em;color:rgba(255,255,255,.82);font-size:clamp(.8rem,1.7vw,1.2rem);font-weight:500}
.video-bar{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--card-2);border:1px solid var(--line);border-top:0;border-radius:0 0 14px 14px;color:var(--text-dim);font-size:.85rem}
.video-bar .track{flex:1;height:4px;border-radius:2px;background:rgba(255,255,255,.12);position:relative}
.video-bar .track::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6%;background:var(--orange);border-radius:2px}
.video-bar svg{width:18px;height:18px}

/* ---------- RATING SUMMARY ---------- */
.panel{background:var(--card-2);border:1px solid var(--line);border-radius:14px;padding:32px 28px}
.panel-title{text-align:center;font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.2em;font-size:1rem;color:#eef1f6;margin-bottom:24px;display:flex;align-items:center;justify-content:center;gap:14px}
.panel-title::before,.panel-title::after{content:"";width:24px;height:1px;background:var(--orange)}
.rating-top{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:8px}
.rating-top .big{font-family:'Saira',sans-serif;font-weight:800;color:var(--orange);font-size:3.4rem;line-height:1}
.rating-top .stars{font-size:1rem;margin:6px 0 2px}
.rating-top .small{font-family:'Saira';text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--text-dim)}
.bars{margin-top:18px;display:flex;flex-direction:column;gap:12px}
.bar-row{display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center}
.bar-row .lbl{font-size:.85rem;color:var(--text-dim)}
.bar-row .num{font-family:'Saira';color:#eef1f6;font-size:.85rem}
.bar-row .track{grid-column:1/3;height:5px;background:rgba(255,255,255,.1);border-radius:3px;position:relative;overflow:hidden}
.bar-row .track i{position:absolute;left:0;top:0;bottom:0;background:var(--orange);border-radius:3px}
.note{margin-top:18px;color:var(--text-faint);font-size:.8rem;text-align:center}

/* critical praise quotes */
.praise{display:flex;flex-direction:column;gap:22px}
.praise .q{color:#dfe5ee;font-size:1rem;line-height:1.5}
.praise .src{display:block;margin-top:6px;font-family:'Saira';text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--orange)}

/* ---------- CHECKLIST (tone & style) ---------- */
.checklist{list-style:none;display:flex;flex-direction:column;gap:16px}
.checklist li{display:flex;align-items:center;gap:14px;color:var(--text)}
.checklist li::before{content:"";width:22px;height:22px;flex:none;border-radius:50%;border:1px solid var(--orange);background:no-repeat center/12px url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f2701c' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E")}

/* ---------- QUOTE CAROUSEL BAND ---------- */
.quote-band{position:relative;border:1px solid var(--line);border-radius:14px;overflow:hidden;padding:46px 70px;text-align:center;background:radial-gradient(120% 140% at 50% 120%,rgba(242,112,28,.18),transparent 60%),linear-gradient(180deg,#0a1018,#06090f)}
.quote-band .q{font-size:1.3rem;color:#eef1f6;line-height:1.45;max-width:760px;margin:0 auto}
.quote-band .src{display:block;margin-top:16px;font-family:'Saira';text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--orange)}
.quote-band .arrow{position:absolute;top:50%;transform:translateY(-50%);background:none;border:0;color:var(--text-dim);cursor:pointer}
.quote-band .arrow svg{width:26px;height:26px}.quote-band .arrow:hover{color:#fff}
.quote-band .arrow.left{left:18px}.quote-band .arrow.right{right:18px}
.dots{display:flex;gap:8px;justify-content:center;margin-top:22px}
.dots i{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2)}
.dots i.on{background:var(--orange)}

/* ---------- AUTHOR / MISSION CARDS (about) ---------- */
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.soft-card{background:var(--card-2);border:1px solid var(--line);border-radius:14px;padding:30px 26px}
.soft-card h3{font-family:'Saira',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.95rem;color:#eef1f6;margin-bottom:20px}
.author-row{display:flex;gap:18px;align-items:flex-start}
.author-row .media{width:120px;flex:none;aspect-ratio:3/4;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.author-row p{color:var(--text-dim);font-size:.92rem}
.mission-quote .mark{font-family:'Saira';color:rgba(242,112,28,.4);font-size:2.4rem;line-height:.4}
.mission-quote p{color:var(--text);margin:10px 0}
.mission-quote .stamp{font-family:'Saira';text-transform:uppercase;letter-spacing:.12em;color:var(--orange);font-size:.85rem;font-weight:600;margin-top:14px}

/* ---------- CTA BAND ---------- */
.cta-band{background:radial-gradient(120% 160% at 90% 120%,rgba(242,112,28,.22),transparent 55%),linear-gradient(180deg,#0a0f1a,#06090f);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:58px 0}
.cta-inner{display:grid;grid-template-columns:auto 1fr auto;gap:40px;align-items:center}
.badge-515{width:124px;height:124px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:'Saira',sans-serif;font-weight:700;font-size:1.9rem;color:#fff;letter-spacing:.05em;border:1px solid rgba(242,112,28,.4);position:relative}
.badge-515::before{content:"";position:absolute;inset:10px;border-radius:50%;border:1px dashed rgba(242,112,28,.45)}
.badge-515::after{content:"";position:absolute;inset:-1px;border-radius:50%;background:conic-gradient(from 0deg,transparent 0 78%,rgba(242,112,28,.8) 80% 88%,transparent 90%);-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 calc(100% - 2px));mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 calc(100% - 2px))}
.cta-text h2{font-family:'Saira',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:clamp(1.4rem,3vw,2.1rem);color:#fff;line-height:1.05}
.cta-text h2 .o{color:var(--orange)}
.cta-text p{color:var(--text-dim);margin-top:10px}
.cta-actions{display:flex;flex-direction:column;gap:12px;min-width:240px}
.cta-actions .btn{justify-content:center}

/* ---------- FOOTER ---------- */
footer{padding:34px 0;background:var(--bg)}
.foot{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.foot .fbrand{font-family:'Saira',sans-serif;letter-spacing:.34em;font-weight:600;color:#eef1f6}
.foot .fbrand b{color:var(--orange)}
.foot .fbrand small{display:block;letter-spacing:.06em;color:var(--text-faint);font-size:.72rem;margin-top:4px}
.foot .copy{color:var(--text-faint);font-size:.85rem}
.socials{display:flex;gap:18px}
.socials a{color:var(--text-dim);transition:color .2s ease}
.socials a:hover{color:var(--orange)}
.socials svg{width:20px;height:20px}

/* ---------- ANIMATION ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .cards-5{grid-template-columns:repeat(2,1fr)}
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .thumb-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav-links{display:none;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;background:#0a0e16;border-bottom:1px solid var(--line);padding:10px 28px}
  .nav-links a{padding:12px 0}
  .nav-toggle{display:block}
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-art{position:relative;width:100%;height:280px;order:-1}
  .hero::before{display:none}
  .hero-copy{padding:46px 0 54px}
  .split{grid-template-columns:1fr;gap:34px}
  .split.img-right .text,.split.img-right .media{order:0}
  .about{grid-template-columns:1fr;gap:32px}
  .book-cover{max-width:260px;margin:0 auto}
  .cards-3,.cards-4,.cards-5,.thumb-grid,.teaser-grid,.three-col{grid-template-columns:1fr}
  .cta-inner{grid-template-columns:1fr;text-align:center;justify-items:center}
  .cta-actions{width:100%}
  .video-frame .overlay-text{display:none}
  .quote-band{padding:40px 26px}.quote-band .arrow{display:none}
  .author-row{flex-direction:column}
}

/* ============================================================
   >>> HIDE ALL IMAGE LABELS WHEN YOU'RE DONE <<<
   Delete the opening  /*  and closing  */  below to activate.
   ============================================================ */
/*
.imgslot::after{display:none !important;}
*/
