/* Cardinal Academy of Technology - whscat.com shared styles */

:root{
  --cardinal:#92150F;
  --cardinal-dark:#6f0f0b;
  --ink:#16181d;
  --muted:#5a6068;
  --line:#e4e6ea;
  --bg:#f6f7f9;
  --card:#ffffff;
  --black:#000000;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"Roboto",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  font-size:16px;
  line-height:1.65;
}
.wrap{max-width:980px;margin:0 auto;padding:0 20px;}
.narrow{max-width:860px;}

a{color:var(--cardinal);text-decoration:underline;text-underline-offset:2px;}
a:hover{color:var(--cardinal-dark);}
img{max-width:100%;display:block;}

/* ---------- Nav ---------- */
.nav{
  background:var(--black);
  color:#fff;
  border-bottom:4px solid var(--cardinal);
  position:sticky;top:0;z-index:50;
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:12px;padding-bottom:12px;flex-wrap:wrap;}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;}
.brand:hover{color:inherit;}
.brand-mark{
  font-family:"Oswald",sans-serif;font-weight:700;letter-spacing:.04em;
  background:var(--cardinal);color:#fff;
  width:38px;height:38px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;font-size:16px;flex:none;
}
.brand-text{font-family:"Oswald",sans-serif;font-weight:600;color:#fff;font-size:15px;letter-spacing:.03em;line-height:1.1;}
.brand-text small{display:block;color:#c9ccd2;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;}
.nav-links{display:flex;gap:20px;flex-wrap:wrap;align-items:center;}
.nav-links a{
  color:#e7e9ec;text-decoration:none;font-family:"Oswald",sans-serif;font-weight:500;
  font-size:14px;letter-spacing:.05em;text-transform:uppercase;
}
.nav-links a:hover{color:#fff;}

/* ---------- Hero ---------- */
.hero{background:var(--card);border-bottom:1px solid var(--line);}
.hero .wrap{padding-top:46px;padding-bottom:46px;text-align:center;}
.hero-logo{max-width:340px;margin:0 auto 22px;}
.hero h1{
  font-family:"Oswald",sans-serif;font-weight:700;
  font-size:clamp(28px,5vw,44px);line-height:1.08;margin:0 0 14px;letter-spacing:.01em;
}
.hero p{max-width:62ch;margin:0 auto;color:#3a3f47;font-size:17px;}
.btnrow{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:26px;}
.btn{
  display:inline-block;font-family:"Oswald",sans-serif;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;font-size:14px;text-decoration:none;padding:11px 22px;border-radius:6px;
  background:var(--cardinal);color:#fff;border:2px solid var(--cardinal);
}
.btn:hover{background:var(--cardinal-dark);border-color:var(--cardinal-dark);color:#fff;}
.btn.outline{background:transparent;color:var(--cardinal);}
.btn.outline:hover{background:var(--cardinal);color:#fff;}

/* ---------- Page header (interior pages) ---------- */
.page-head{background:var(--black);color:#fff;border-bottom:5px solid var(--cardinal);}
.page-head .wrap{padding-top:34px;padding-bottom:30px;}
.eyebrow{
  font-family:"Oswald",sans-serif;letter-spacing:.18em;text-transform:uppercase;
  font-size:13px;color:#d98a86;margin:0 0 8px;
}
.page-head h1{font-family:"Oswald",sans-serif;font-weight:700;font-size:clamp(26px,5vw,40px);line-height:1.1;margin:0;}
.page-head p.sub{margin:14px 0 0;color:#c9ccd2;max-width:60ch;font-size:15px;}
.updated{
  display:inline-block;margin-top:18px;font-family:"Oswald",sans-serif;font-size:12px;
  letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--cardinal);
  padding:5px 12px;border-radius:3px;
}

/* ---------- Sections ---------- */
main{padding-top:8px;padding-bottom:40px;}
section{padding-top:30px;}
h2{
  font-family:"Oswald",sans-serif;font-weight:600;color:var(--cardinal);font-size:24px;
  margin:40px 0 6px;padding-bottom:8px;border-bottom:2px solid var(--line);letter-spacing:.01em;
}
h3{font-family:"Oswald",sans-serif;font-weight:600;color:var(--ink);font-size:18px;margin:24px 0 4px;}
p{margin:10px 0;}
ul{margin:10px 0;padding-left:22px;}
li{margin:6px 0;}
strong{font-weight:700;}
.lead{font-size:17px;color:#2b2f36;}
.muted{color:var(--muted);font-size:14px;}
code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.92em;background:#eef0f3;padding:1px 5px;border-radius:4px;}

/* ---------- App cards (hub) ---------- */
.apps-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:18px;}
.app-card{
  background:var(--card);border:1px solid var(--line);border-left:5px solid var(--cardinal);
  border-radius:8px;padding:18px 20px;display:flex;flex-direction:column;
}
.app-card h3{margin:0 0 2px;}
.app-card .host{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;color:var(--muted);margin-bottom:8px;}
.app-card p{margin:0 0 14px;font-size:15px;color:#3a3f47;flex:1;}
.app-card .open{
  align-self:flex-start;font-family:"Oswald",sans-serif;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;font-size:13px;text-decoration:none;color:var(--cardinal);
}
.app-card .open:hover{color:var(--cardinal-dark);}
.card-links{display:flex;gap:20px;flex-wrap:wrap;align-items:center;align-self:flex-start;}

/* ---------- Policy/content blocks ---------- */
.app{
  background:var(--card);border:1px solid var(--line);border-left:5px solid var(--cardinal);
  border-radius:8px;padding:18px 22px 6px;margin:18px 0;
}
.app h3{margin-top:6px;}
.app .url{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;color:var(--muted);}
.pill{
  display:inline-block;font-family:"Oswald",sans-serif;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;padding:3px 9px;border-radius:20px;margin:2px 4px 2px 0;
  background:#f0e3e2;color:var(--cardinal-dark);border:1px solid #e6cfcd;
}
.callout{
  background:#fff;border:1px solid var(--line);border-top:4px solid var(--cardinal);
  border-radius:8px;padding:18px 22px;margin:20px 0;
}
.callout h2{margin-top:4px;border:none;padding-bottom:0;}

/* ---------- Tables ---------- */
.table-scroll{overflow-x:auto;margin:18px 0;border:1px solid var(--line);border-radius:8px;}
table{border-collapse:collapse;width:100%;min-width:680px;background:var(--card);font-size:14px;}
th,td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:top;}
thead th{
  background:#000;color:#fff;font-family:"Oswald",sans-serif;font-weight:500;
  letter-spacing:.04em;font-size:13px;text-transform:uppercase;border-bottom:none;
}
tbody tr:last-child td{border-bottom:none;}
td:first-child{font-weight:700;white-space:nowrap;}

/* ---------- Footer ---------- */
.site-footer{background:var(--black);color:#cfd2d7;margin-top:46px;}
.site-footer .wrap{padding-top:34px;padding-bottom:30px;display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:26px;}
.site-footer h4{font-family:"Oswald",sans-serif;color:#fff;font-size:14px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 10px;}
.site-footer a{color:#f0b3af;text-decoration:none;}
.site-footer a:hover{text-decoration:underline;}
.site-footer ul{list-style:none;padding:0;margin:0;}
.site-footer li{margin:5px 0;}
.site-footer .org{font-family:"Oswald",sans-serif;color:#fff;font-size:16px;margin-bottom:4px;}
.foot-bottom{border-top:1px solid #2a2a2a;}
.foot-bottom .wrap{padding-top:14px;padding-bottom:18px;display:block;text-align:center;color:#8b9097;font-size:13px;}

@media (max-width:720px){
  .apps-grid{grid-template-columns:1fr;}
  .site-footer .wrap{grid-template-columns:1fr;gap:20px;}
  body{font-size:15px;}
}
