/* Albion Ports — shared styles */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0C2340; --navy-dk:#081A30; --red:#CF142B; --gold:#C8A55B;
  --cream:#FAF6EE; --paper:#FFFFFF; --sand:#ECE4CE; --rule:#D5CBB0;
  --muted:#736B5C; --text:#1A1914; --ink:#0A0E1A;
  --serif:'Playfair Display',Georgia,serif;
  --body:'Source Serif 4',Georgia,serif;
  --ui:'DM Sans',system-ui,sans-serif;
}
html,body{background:var(--cream);color:var(--text);font-family:var(--body);font-size:17px;line-height:1.78;min-height:100vh}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ─── Masthead ─── */
.masthead{background:var(--navy);padding:30px 44px;border-bottom:5px solid var(--red);position:relative;overflow:hidden}
.masthead::before{content:"";position:absolute;top:0;right:0;bottom:0;left:50%;background:
  linear-gradient(rgba(207,20,43,.08),rgba(207,20,43,.08)),
  linear-gradient(135deg,transparent 48%,rgba(255,255,255,.03) 49%,rgba(255,255,255,.03) 51%,transparent 52%);
  pointer-events:none}
.masthead .issue{font-family:var(--ui);font-size:10px;letter-spacing:.45em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;position:relative}
.masthead .brand{font-family:var(--serif);font-size:clamp(38px,6vw,74px);font-weight:900;line-height:1;letter-spacing:-.02em;color:#fff;position:relative}
.masthead .brand em{font-style:italic;color:var(--red)}
.masthead .tag{font-family:var(--body);font-style:italic;font-size:16px;color:rgba(255,255,255,.6);margin-top:8px;position:relative}

/* ─── Nav ─── */
nav.bar{background:var(--paper);border-bottom:1px solid var(--rule);display:flex;align-items:center;padding:0 44px;overflow-x:auto}
nav.bar a{font-family:var(--ui);font-size:11px;letter-spacing:.22em;text-transform:uppercase;padding:16px 14px;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color .15s}
nav.bar a:hover{color:var(--navy)}
nav.bar a.on{color:var(--red);border-bottom-color:var(--red)}
nav.bar .dot{width:3px;height:3px;border-radius:50%;background:var(--rule);margin:0 4px}

/* ─── Hero ─── */
.hero{position:relative;min-height:420px;display:flex;align-items:flex-end;color:#fff;overflow:hidden;isolation:isolate;background:var(--ink);border-bottom:5px double var(--gold)}
.hero .himg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-1;opacity:.5;filter:contrast(1.05)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,35,64,0) 0%,rgba(12,35,64,.6) 60%,rgba(12,35,64,.95) 100%);z-index:-1}
.hero-inner{padding:72px 44px 56px;max-width:1200px}
.hero .kicker{font-family:var(--ui);font-size:10.5px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.hero h1{font-family:var(--serif);font-weight:900;font-size:clamp(32px,5.2vw,64px);line-height:1.06;letter-spacing:-.02em;color:#fff;max-width:22ch}
.hero .lede{margin-top:18px;font-family:var(--body);font-style:italic;font-size:clamp(16px,1.5vw,20px);max-width:44ch;color:rgba(255,255,255,.82);line-height:1.55}
.hero .accent{width:120px;height:2px;background:var(--red);margin-top:24px}

/* ─── Layout ─── */
main{max-width:1200px;margin:0 auto;padding:64px 44px 96px;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:56px;align-items:start}
@media(max-width:900px){main{grid-template-columns:1fr;gap:36px;padding:40px 20px 64px}.hero-inner{padding:48px 20px 32px}.masthead{padding:22px 20px}nav.bar{padding:0 20px}}

h2{font-family:var(--serif);font-size:30px;font-weight:700;letter-spacing:-.015em;margin-bottom:18px;padding-bottom:14px;border-bottom:1px double var(--rule);color:var(--navy)}
h3{font-family:var(--serif);font-size:22px;font-weight:700;line-height:1.2;color:var(--navy);margin:20px 0 10px}
p{margin-bottom:14px}

.intro{font-size:19px;font-style:italic;color:var(--text);max-width:40em;margin-bottom:36px;line-height:1.6;padding-left:20px;border-left:3px solid var(--red)}

/* Entry cards (chapter pages) */
.entry{padding:34px 0;border-bottom:1px solid var(--rule);display:grid;grid-template-columns:minmax(0,320px) minmax(0,1fr);gap:30px;align-items:flex-start}
.entry:last-of-type{border-bottom:none}
@media(max-width:720px){.entry{grid-template-columns:1fr;gap:18px;padding:26px 0}}
.entry figure{position:relative;overflow:hidden;background:var(--sand);aspect-ratio:4/3}
.entry figure img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.entry figure:hover img{transform:scale(1.04)}
.entry figure figcaption{position:absolute;top:10px;left:10px;background:var(--red);color:#fff;font-family:var(--ui);font-size:10px;font-weight:600;letter-spacing:.25em;padding:4px 10px;text-transform:uppercase}
.entry .code{font-family:var(--ui);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.entry h3{margin-top:0}
.entry .meta{display:flex;flex-wrap:wrap;gap:12px;margin:14px 0;font-family:var(--ui);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.entry .meta span{background:var(--paper);padding:6px 10px;border:1px solid var(--rule)}
.entry p{font-size:16px;color:#33302B;line-height:1.76;max-width:42em}

/* Home grid */
.idx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1px;background:var(--rule);border:1px solid var(--rule);margin-top:32px}
.idx-cell{background:var(--paper);padding:26px 22px;display:flex;flex-direction:column;gap:10px;min-height:160px;transition:background .18s;position:relative}
.idx-cell::after{content:"→";position:absolute;bottom:18px;right:20px;color:var(--gold);opacity:.4;font-family:var(--ui);transition:all .2s}
.idx-cell:hover{background:var(--navy)}
.idx-cell:hover .lbl{color:var(--gold)}
.idx-cell:hover .ttl{color:#fff}
.idx-cell:hover .hint{color:rgba(255,255,255,.62)}
.idx-cell:hover::after{color:var(--red);opacity:1;transform:translateX(4px)}
.idx-cell .lbl{font-family:var(--ui);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);transition:color .2s}
.idx-cell .ttl{font-family:var(--serif);font-size:24px;font-weight:700;letter-spacing:-.01em;color:var(--navy);transition:color .2s}
.idx-cell .hint{font-size:14px;font-style:italic;color:var(--muted);margin-top:auto;transition:color .2s}

/* Stats strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:32px 0 12px;border:1px solid var(--rule);background:var(--paper)}
@media(max-width:640px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{padding:22px 18px;border-right:1px solid var(--rule)}
.stat:last-child{border-right:0}
.stat .n{font-family:var(--serif);font-weight:900;font-size:34px;color:var(--navy);letter-spacing:-.02em;line-height:1}
.stat .l{font-family:var(--ui);font-size:10px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;margin-top:8px}

/* Sidebar */
aside{position:sticky;top:16px;background:var(--navy);color:#fff;padding:28px;border-top:5px solid var(--red);position:relative;overflow:hidden}
aside::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at bottom right,rgba(200,165,91,.12),transparent 65%);pointer-events:none}
aside h4{font-family:var(--ui);font-size:10.5px;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;position:relative}
aside p{font-size:14px;line-height:1.62;color:rgba(255,255,255,.78);margin-bottom:12px;position:relative}
aside .quote{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--gold);margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.14);position:relative}

/* Footer */
footer{background:var(--navy);border-top:5px solid var(--red);padding:32px 44px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-family:var(--ui);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.55)}
footer .fl{color:var(--gold)}
@media(max-width:720px){footer{padding:24px 20px}}

.ornament{text-align:center;color:var(--gold);letter-spacing:.5em;margin:26px 0;font-size:13px;opacity:.7}
