/* The Magical Stranger — Stephen Rodrick. Restored static site. */
:root{
  --ink:#1a1f2b;
  --ink-soft:#3a4254;
  --paper:#f7f5f0;
  --paper-2:#efece4;
  --line:#d9d4c8;
  --accent:#9a2f2a;       /* deep crimson */
  --accent-2:#c9a227;     /* muted gold */
  --navy:#162033;         /* deep navy (sea / night) */
  --white:#ffffff;
  --shadow:0 10px 30px rgba(22,32,51,.14);
  --maxw:1120px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html,body{margin:0;padding:0;overflow-x:hidden}
body{
  font-family:"Lato","Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:"Playfair Display",Georgia,"Times New Roman",serif;line-height:1.18;color:var(--ink);font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(2rem,6vw,3.4rem)}
h2{font-size:clamp(1.5rem,4.2vw,2.3rem)}
h3{font-size:clamp(1.15rem,2.6vw,1.4rem)}
p{margin:0 0 1.1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.eyebrow{font-family:"Lato",sans-serif;text-transform:uppercase;letter-spacing:.22em;font-size:.78rem;font-weight:700;color:var(--accent);margin:0 0 .8em}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(247,245,240,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:var(--maxw);margin:0 auto;padding:14px 20px}
.brand{display:flex;flex-direction:column;line-height:1;text-decoration:none}
.brand .b-title{font-family:"Playfair Display",Georgia,serif;font-weight:700;font-size:clamp(1.05rem,3.4vw,1.5rem);color:var(--ink);letter-spacing:.02em}
.brand .b-sub{font-family:"Lato",sans-serif;text-transform:uppercase;letter-spacing:.28em;font-size:.62rem;color:var(--ink-soft);margin-top:5px;font-weight:700}
.brand:hover{text-decoration:none}
.nav{display:flex;align-items:center;gap:4px}
.nav a{font-family:"Lato",sans-serif;text-transform:uppercase;letter-spacing:.13em;font-size:.78rem;font-weight:700;color:var(--ink-soft);padding:10px 12px;border-radius:6px}
.nav a:hover,.nav a.active{color:var(--accent);text-decoration:none;background:var(--paper-2)}
.cta-btn{display:inline-block;background:var(--accent);color:#fff!important;font-family:"Lato",sans-serif;text-transform:uppercase;letter-spacing:.13em;font-size:.78rem;font-weight:700;padding:11px 18px;border-radius:6px;border:1px solid var(--accent)}
.cta-btn:hover{background:#7e2521;text-decoration:none}
.nav-cta{margin-left:8px}
.menu-toggle{display:none;background:none;border:1px solid var(--line);border-radius:6px;width:44px;height:44px;cursor:pointer;align-items:center;justify-content:center;flex:0 0 auto}
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{display:block;width:20px;height:2px;background:var(--ink);position:relative;transition:.2s}
.menu-toggle span::before{content:"";position:absolute;top:-6px;left:0}
.menu-toggle span::after{content:"";position:absolute;top:6px;left:0}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(180deg,var(--navy),#0e1626);color:#f3f1ea;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 80% -10%,rgba(201,162,39,.16),transparent 55%);pointer-events:none}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,7vw,86px) 20px;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,5vw,64px);align-items:center;position:relative;z-index:2}
.hero h1{color:#fff}
.hero .eyebrow{color:var(--accent-2)}
.hero p.lede{font-size:clamp(1.05rem,2.4vw,1.32rem);color:#d7dae2;max-width:34ch}
.hero .btns{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.btn-ghost{display:inline-block;color:#fff!important;border:1px solid rgba(255,255,255,.5);padding:11px 18px;border-radius:6px;font-family:"Lato",sans-serif;text-transform:uppercase;letter-spacing:.13em;font-size:.78rem;font-weight:700}
.btn-ghost:hover{background:rgba(255,255,255,.1);text-decoration:none}
.book-cover{margin:0 auto;max-width:330px;width:100%;border-radius:6px;box-shadow:0 24px 60px rgba(0,0,0,.5);transform:rotate(-2deg)}

/* ---------- Sections ---------- */
.section{padding:clamp(46px,7vw,84px) 0}
.section.alt{background:var(--paper-2)}
.section.dark{background:var(--navy);color:#e9ebf0}
.section.dark h2,.section.dark h3{color:#fff}
.section.dark .eyebrow{color:var(--accent-2)}
.center{text-align:center}
.center .lede{max-width:62ch;margin-left:auto;margin-right:auto;color:var(--ink-soft)}
.lede{font-size:1.12rem;color:var(--ink-soft)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,60px);align-items:center}
.split.narrow-img{grid-template-columns:.8fr 1.2fr}
.prose p{max-width:66ch}
.figure{border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}
.figure img{width:100%}
.cap{font-size:.82rem;color:var(--ink-soft);margin-top:8px;font-style:italic}

/* ---------- Praise quotes ---------- */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:40px}
.quote{background:var(--white);border:1px solid var(--line);border-top:4px solid var(--accent);border-radius:8px;padding:28px;box-shadow:var(--shadow)}
.quote p{font-family:"Playfair Display",Georgia,serif;font-size:1.15rem;font-style:italic;color:var(--ink);margin:0 0 .8em}
.quote .src{font-family:"Lato",sans-serif;font-style:normal;font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:700}
.pull{font-family:"Playfair Display",Georgia,serif;font-size:clamp(1.4rem,3.6vw,2rem);font-style:italic;line-height:1.4;text-align:center;max-width:24ch;margin:0 auto}

/* ---------- Gallery ---------- */
.grid-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;margin-top:36px}
.grid-gallery figure{margin:0}
.grid-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:6px;box-shadow:var(--shadow)}
.grid-gallery figcaption{font-size:.82rem;color:var(--ink-soft);margin-top:8px}

/* ---------- Video ---------- */
.video-wrap{max-width:880px;margin:36px auto 0;border-radius:8px;overflow:hidden;box-shadow:var(--shadow);background:#000}
.video-frame{position:relative;width:100%;padding-top:56.25%}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- Events ---------- */
.events-list{margin:36px auto 0;max-width:760px}
.event{display:flex;gap:22px;align-items:baseline;background:var(--white);border:1px solid var(--line);border-radius:8px;padding:22px 24px;margin-bottom:16px;box-shadow:var(--shadow)}
.event .date{font-family:"Playfair Display",Georgia,serif;font-weight:700;color:var(--accent);font-size:1.05rem;flex:0 0 110px}
.event .meta h3{margin:0 0 4px;font-size:1.12rem}
.event .meta p{margin:0;color:var(--ink-soft);font-size:.95rem}
.note{background:var(--paper-2);border:1px dashed var(--line);border-radius:8px;padding:18px 22px;color:var(--ink-soft);font-size:.95rem;max-width:760px;margin:24px auto 0;text-align:center}

/* ---------- CTA band ---------- */
.cta-band{background:var(--accent);color:#fff;text-align:center;padding:clamp(40px,6vw,70px) 20px}
.cta-band h2{color:#fff}
.cta-band p{color:#ffe7e2;max-width:54ch;margin:0 auto 1.4em}
.cta-band .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-band .cta-btn{background:#fff;color:var(--accent)!important;border-color:#fff}
.cta-band .cta-btn:hover{background:var(--paper)}
.cta-band .btn-ghost{border-color:rgba(255,255,255,.7)}

/* ---------- Footer ---------- */
.site-footer{background:#0e1626;color:#aeb6c6;padding:46px 0 30px}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:0 20px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px}
.site-footer a{color:#d7dae2}
.site-footer .f-brand{font-family:"Playfair Display",Georgia,serif;font-size:1.3rem;color:#fff;margin-bottom:8px}
.fnav{display:flex;flex-wrap:wrap;gap:6px 18px}
.fnav a{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em}
.copyright{width:100%;border-top:1px solid rgba(255,255,255,.12);margin-top:26px;padding-top:18px;font-size:.82rem;color:#8a93a6}

/* breadcrumb on inner pages */
.crumb{font-size:.8rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.crumb a{color:var(--accent)}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .nav{position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:stretch;background:var(--paper);border-bottom:1px solid var(--line);padding:10px 16px 18px;gap:2px;display:none;box-shadow:var(--shadow)}
  .nav.open{display:flex}
  .nav a{padding:13px 8px;border-radius:6px;font-size:.9rem}
  .nav-cta{margin:8px 0 0}
  .cta-btn{display:block;text-align:center}
  .menu-toggle{display:flex}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero p.lede{margin-left:auto;margin-right:auto}
  .hero .btns{justify-content:center}
  .book-cover{transform:none;max-width:260px}
  .split,.split.narrow-img{grid-template-columns:1fr}
  .order-img-first .figure{order:-1}
}
@media(max-width:520px){
  body{font-size:16px}
  .event{flex-direction:column;gap:6px}
  .event .date{flex-basis:auto}
}
