/* lexiesdesk.com.au — clean white / black / blue, Arial.
   Design brief (Lexie): white background, black wording, blue accents,
   Arial type, eye travels left→right, all books on one screen. */

:root{
  --blue:#0a4d8c;        /* confident primary blue */
  --blue-dark:#073a6b;
  --blue-tint:#eaf2fb;   /* pale blue wash */
  --ink:#111111;
  --muted:#5a5a5a;
  --line:#d9e2ec;
  --maxw:1200px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:Arial,Helvetica,sans-serif;
  color:var(--ink);
  background:#ffffff;
  line-height:1.55;
}
a{color:var(--blue)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- header ---------- */
header.site{background:#fff;border-bottom:2px solid var(--blue)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px}
header.site .brand{font-size:1.35rem;font-weight:bold;color:var(--ink);
  text-decoration:none;letter-spacing:.2px}
header.site .brand span{display:block;font-size:.72rem;font-weight:normal;
  color:var(--muted);letter-spacing:.5px;text-transform:uppercase}
header.site nav a{margin-left:22px;text-decoration:none;color:var(--ink);
  font-size:.95rem}
header.site nav a:hover{color:var(--blue)}

/* ---------- banner ---------- */
.banner{background:var(--blue-tint);border-bottom:1px solid var(--line)}
.banner .wrap{display:flex;align-items:center;gap:24px;padding:12px 24px}
.banner img.mark{height:78px;width:auto;flex:0 0 auto}
.banner .quote{font-size:1.2rem;line-height:1.4;color:var(--ink);max-width:860px}
.banner .quote .cite{display:block;text-align:right;font-size:.9rem;color:var(--blue);
  font-style:normal;margin-top:2px}
@media(max-width:640px){
  .banner .wrap{flex-direction:column;text-align:center;gap:16px}
  .banner img.mark{height:100px}
  .banner .quote{font-size:1.1rem}
}

/* ---------- books row ---------- */
.shelf{padding:12px 0 6px}
.shelf h2{font-size:1.4rem;margin:0 0 6px}
.shelf .sub{color:var(--muted);margin:0 0 22px;font-size:.95rem}
.shelf .author{margin:0 0 14px}
.shelf .author h3{font-size:1.1rem;margin:0 0 4px}
.shelf .author p{margin:0;max-width:none;font-size:.95rem;line-height:1.45}
.books{display:flex;gap:14px;align-items:stretch}
.book{flex:1 1 0;min-width:0;display:flex;flex-direction:column;
  border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff;
  transition:box-shadow .15s,transform .15s}
.book:hover{box-shadow:0 6px 18px rgba(10,77,140,.14);transform:translateY(-2px)}
.book .cover{height:185px;background:#fff;border-bottom:1px solid var(--line);overflow:hidden}
.book .cover img{width:100%;height:100%;object-fit:cover;display:block}
.book .cover .ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  box-sizing:border-box;text-align:center;padding:14px;color:var(--blue-dark);
  font-size:.95rem;font-weight:bold}
.book .body{padding:12px 14px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.book .title{font-size:1.02rem;font-weight:bold;line-height:1.3}
.book .price{color:var(--blue);font-weight:bold}
.book .price small{color:var(--muted);font-weight:normal}
.book .soon{color:var(--muted);font-style:italic;margin-top:auto}
.book .act{margin-top:auto;padding-top:6px}
.btn{display:inline-block;background:var(--blue);color:#fff;border:0;border-radius:6px;
  padding:9px 14px;font:inherit;font-size:.9rem;text-decoration:none;cursor:pointer;
  text-align:center;width:100%}
.btn:hover{background:var(--blue-dark)}
.btn.ghost{background:#fff;color:var(--blue);border:1px solid var(--blue);width:auto}
.btn.ghost:hover{background:var(--blue-tint)}
@media(max-width:980px){.books{flex-wrap:wrap}.book{flex:1 1 30%}}
@media(max-width:600px){.book{flex:1 1 100%}}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;background:rgba(17,17,17,.55);display:none;
  align-items:center;justify-content:center;padding:20px;z-index:50}
.modal.open{display:flex}
.modal .panel{background:#fff;border-radius:10px;max-width:580px;width:100%;
  max-height:86vh;overflow:auto;padding:26px 28px;position:relative}
.modal .panel h3{margin:0 6px 4px 0;font-size:1.4rem}
.modal .panel .meta{color:var(--blue);font-weight:bold;margin:0 0 14px}
.modal .panel .meta small{color:var(--muted);font-weight:normal;display:block;
  margin-top:2px}
.modal .panel p.desc{margin:0 0 18px;white-space:pre-line}
.modal .close{position:absolute;top:12px;right:14px;border:0;background:none;
  font-size:1.6rem;line-height:1;color:var(--muted);cursor:pointer}
.modal .close:hover{color:var(--ink)}

/* ---------- about ---------- */
.about{background:#fff;border-top:1px solid var(--line);margin-top:28px}
.about .wrap{padding:22px 24px}
.about h2{margin:0 0 10px;font-size:1.4rem}
.about p{max-width:760px;margin:0 0 12px}

/* favourite-books modal list */
.modal .panel ul.faves{margin:6px 0 0;padding-left:1.1em;columns:2;column-gap:28px}
.modal .panel ul.faves li{margin:0 0 7px;break-inside:avoid}
.modal .panel ul.faves .by{color:var(--muted)}
@media(max-width:520px){.modal .panel ul.faves{columns:1}}

/* ---------- generic + forms ---------- */
.muted{color:var(--muted)}
.notice{background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);
  padding:14px 18px;border-radius:6px;margin:18px 0}
label{display:block;margin:14px 0 4px;font-size:.95rem;font-weight:bold}
input[type=text],input[type=email],input[type=tel],input[type=number],textarea,select{
  width:100%;max-width:440px;padding:9px 11px;border:1px solid var(--line);
  border-radius:6px;font:inherit;background:#fff}
.product{display:grid;grid-template-columns:300px 1fr;gap:36px;margin-top:24px}
.product .cover{aspect-ratio:3/4;background:var(--blue-tint);border:1px solid var(--line);
  border-radius:8px}
.product .cover img{width:100%;height:100%;object-fit:cover;border-radius:8px}
@media(max-width:680px){.product{grid-template-columns:1fr}}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--blue);color:var(--muted);font-size:.85rem}
footer.site .wrap{padding:10px 24px}
