/* =====================================================================
   style.css — PLaw-aligned layout + typography for The Cognitive Craftsman™
   - Responsive grid layout (sidebar + main content)
   - Visible focus states + skip link
   - "Road sign" link treatment (brand blue)
   - Cards for sidebar + notices
   ===================================================================== */

/* ---- Modern variables & global defaults ---- */
:root{
  --brand-blue:#1C75BC;
  --brand-black:#000000;
  --text:#4C4C4C;
  --bg:#FFFFFF;
  --muted:#6A6A6A;
  --card-border:#D9D9D9;
  --line:var(--card-border);
  --focus:#1C75BC;

  /* Accent used by legacy `.gold` class in your content */
  --gold:#B08A00;

  /* Retro-Modern sans-serif (PLaw default) */
  --body-font:'Trebuchet MS','Segoe UI',Tahoma,Verdana,Arial,Helvetica,sans-serif;

  /* Fluid container width */
  --wrap-min:980px;
  --wrap-fluid:92vw;
  --wrap-max:1400px;

  --img-radius:12px;
}

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

html{ font-size:18px; }

body{
  margin:0;
  padding:0;
  font-family:var(--body-font);
  font-size:1rem;
  line-height:1.65;
  color:var(--text);
  background:var(--bg);
  font-weight:400;
}

img{ max-width:100%; height:auto; border:0; }

/* Trademark mark */
.tm{
  font-size:0.8em;
  vertical-align:super;
}

/* ---- Links: "road sign" treatment ---- */
a,
a:visited{
  color:var(--brand-blue);
  text-decoration:none;
  border-bottom:1px solid rgba(28,117,188,0.55);
  padding-bottom:0.02em;
  text-underline-offset:0.15em;
}

a:hover,
a:active{
  color:var(--brand-black);
  border-bottom-color:rgba(0,0,0,0.55);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible{
  outline:3px solid var(--focus);
  outline-offset:2px;
  border-radius:10px;
}

/* Skip link for keyboard/screen-reader users */
.skip-link{
  position:absolute;
  left:-9999px;
  top:0;
  background:#FFFFFF;
  color:var(--brand-blue);
  padding:10px 14px;
  border:2px solid var(--brand-blue);
  border-radius:12px;
}
.skip-link:focus{
  left:12px;
  top:12px;
  z-index:9999;
}

/* ---- Stealth headings (PLaw style) ---- */
h1,h2,h3,h4,h5,h6{
  font-family:inherit;
  font-size:1em;
  font-weight:inherit;
  line-height:inherit;
  margin:0 0 1rem;
  color:inherit;
}

/* ---- Layout ---- */
.site-wrap{
  width:100%;
  max-width:clamp(var(--wrap-min), var(--wrap-fluid), var(--wrap-max));
  margin:0 auto;
  padding:24px 16px 48px;
}

.layout{
  display:grid;
  grid-template-columns:360px minmax(0,1fr);
  grid-template-areas:"sidebar main";
  gap:34px;
  align-items:start;
}

.sidebar{ grid-area:sidebar; }
.main-content{ grid-area:main; min-width:0; }

@media (max-width: 900px){
  .site-wrap{ padding:16px 14px 40px; }
  .layout{
    grid-template-columns:1fr;
    grid-template-areas:
      "main"
      "sidebar";
    gap:22px;
  }
}


/* Logo link: remove underline/border */
.logo-link{ display:block; border-bottom:0 !important; text-decoration:none; }
.logo-link svg{ display:block; width:100%; max-width:260px; height:auto; }

/* ---- Sidebar ---- */
.logo-block{ margin:6px 0 14px; }

.logo-text{
  font-weight:700;
  color:var(--brand-black);
  line-height:1.25;
}

.logo-caption{
  display:block;
  font-weight:400;
  color:var(--muted);
  font-size:0.92rem;
  margin-top:4px;
}

.sidebar-card{
  background:#FFFFFF;
  border:1px solid var(--card-border);
  border-radius:16px;
  padding:16px 18px;
  margin:0 0 18px;
  box-shadow:0 1px 2px rgba(0,0,0,0.06);
  text-align:left;
}

/* Sidebar: force non-bold text (PLaw behavior) */
.sidebar-card,
.sidebar-card *{
  font-weight:400;
}

.card-title{
  margin:0 0 10px;
  font-weight:700;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.02em;
  text-align:center;
}

.book-link{
  display:block;
  text-align:center;
  border:1px solid var(--card-border);
  border-radius:12px;
  padding:10px;
  border-bottom:1px solid var(--card-border); /* override link underline */
}
.book-link:hover{ border-color:rgba(0,0,0,0.35); }
.book-link img{ border-radius:10px; }

.label{
  margin:0 0 6px;
  color:var(--text);
  font-size:14px;
  font-weight:500;
}

.line-item{ margin:0; }

.spacer{ height:12px; }

.vcard{ text-align:left; }

/* ---- Top navigation (X-Large) ---- */
.site-nav{
  margin:56px 0 24px;
}

.site-nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:nowrap;
  justify-content:space-between;
  align-items:center;
  gap:10px;
}

.site-nav a{
  display:inline-block;
  padding:6px 6px;
  font-size:1.3rem;
  font-weight:700;
  white-space:nowrap;
}

@media (max-width: 700px){
  .site-nav ul{
    flex-wrap:wrap;
    justify-content:center;
    gap:12px;
  }
  .site-nav a{
    padding:10px 10px;
    font-size:1.15rem;
  }
}

/* ---- Main content ---- */
.content{ text-align:justify; }

@media (max-width: 700px){
  .content{ text-align:left; }
}

.content p{ margin:0 0 1rem; }

/* Keep bullets for content lists (override PLaw legacy ul reset) */
.content ul{
  list-style:disc;
  margin:0 0 1rem 1.3rem;
  padding:0;
}
.content li{ margin:0.35rem 0; }

/* Title/subtitle helpers */
.page-title{
  margin:0 0 0.6rem;
}
.page-subtitle{
  margin:0 0 1.2rem;
}

.gold{ color:var(--gold); }

/* Cards in main content */
.card{
  background:#FFFFFF;
  border:1px solid var(--card-border);
  border-radius:16px;
  padding:16px 18px;
  margin:16px 0 0;
  box-shadow:0 1px 2px rgba(0,0,0,0.06);
}

.small{ font-size:0.9rem; }
.muted{ color:var(--muted); }

/* ---- Footer ---- */
.site-footer{
  margin-top:28px;
  text-align:center;
}

.site-footer p{ margin:0 0 10px; }

.footer-sep{
  margin:0 6px;
  color:var(--muted);
}

/* Keep body unbolded (PLaw behavior) */
b, strong{ font-weight:400; }

/* ============================================================
   Contact form + vCard (PLaw-style sidebar)
   ============================================================ */

.nowrap{ white-space:nowrap; }

.vcard .fn.org{
  font-weight:700;
  margin:0 0 8px;
}

.vcard .adr{ margin:0 0 10px; }

/* Sidebar contact form */
.sidebar-card form{ margin:0; }

.sidebar-card form input[type="text"],
.sidebar-card form input[type="email"],
.sidebar-card form input[type="tel"],
.sidebar-card form textarea{
  width:100%;
  box-sizing:border-box;
  border:1px solid var(--card-border);
  border-radius:10px;
  padding:10px 12px;
  background:#FFFFFF;
  color:var(--text);
  margin:6px 0;
}

.sidebar-card form textarea::placeholder{
  white-space:normal;
}

.sidebar-card form textarea{
  min-height:120px;
  resize:vertical;
}

.sidebar-card form input[type="submit"],
.sidebar-card form button[type="submit"]{
  width:100%;
  box-sizing:border-box;
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  border:0;
  background:var(--brand-blue);
  color:#FFFFFF;
  font-weight:700;
  cursor:pointer;
}

.sidebar-card form input[type="submit"]:hover,
.sidebar-card form button[type="submit"]:hover{
  filter:brightness(0.95);
}

.sidebar-card form input[type="submit"]:focus,
.sidebar-card form button[type="submit"]:focus,
.sidebar-card form input[type="text"]:focus,
.sidebar-card form input[type="email"]:focus,
.sidebar-card form input[type="tel"]:focus,
.sidebar-card form textarea:focus{
  outline:2px solid var(--focus);
  outline-offset:2px;
}

/* Honeypot: hidden from humans, visible to many bots */
.contact-honeypot{
  position:absolute !important;
  left:-10000px !important;
  top:auto !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
}
