/*
Theme Name: CULogics
Theme URI: https://culogics.com
Author: Ricky Spears
Author URI: https://culogics.com
Description: A clean, modern WordPress theme for CU Logics — strategic AI & systems advisory for credit unions. Gutenberg-friendly, fast, and professional.
Version: 1.1.1
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: culogics
Tags: custom-logo, blog, one-column, wide-blocks, translation-ready
*/

:root{
  --cul-blue: #0B2D4D;
  --cul-gray: #5B6066;
  --cul-ink:  #0B0F14;
  --cul-accent: #465870;  /* slate blue-gray */
  --cul-bg: #FFFFFF;
  --cul-surface: #F6F8FA;
  --cul-border: #E6E8EB;
  --cul-radius: 14px;
  --cul-shadow: 0 8px 28px rgba(15, 23, 42, 0.08);
  --cul-maxw: 1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--cul-ink);
  background:var(--cul-bg);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Inter, Roboto, Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji";
  line-height:1.55;
}
a{color:var(--cul-blue); text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%; height:auto}
hr{border:0; border-top:1px solid var(--cul-border); margin:2.25rem 0}
code, pre{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace}

.container{
  width: min(var(--cul-maxw), calc(100% - 2rem));
  margin: 0 auto;
}

.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--cul-border);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  padding: .85rem 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:.75rem;
  min-width: 180px;
}
.brand img{
  display:block;
  height: 34px;
  width:auto;
}
.nav-wrap{
  display:flex;
  align-items:center;
  gap: .75rem;
}
.primary-nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:.35rem;
  align-items:center;
  flex-wrap: wrap;
}
.primary-nav a{
  display:inline-block;
  padding:.55rem .7rem;
  border-radius: 999px;
  font-weight: 600;
  color: var(--cul-ink);
}
.primary-nav a:hover{
  text-decoration:none;
  background: var(--cul-surface);
}
.primary-nav .current-menu-item > a,
.primary-nav .current_page_item > a{
  background: rgba(70,88,112,.14);
  border: 1px solid rgba(70,88,112,.28);
  color: var(--cul-ink);
}
.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.6rem .95rem;
  border-radius: 999px;
  background: var(--cul-accent);
  color:#fff;
  font-weight: 700;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: none;
  white-space: nowrap;
}
.cta:hover{
  text-decoration:none;
  background: #3B4C61; /* slightly darker than #465870 */
}
.cta:focus{ outline: 3px solid rgba(70,88,112,.35); outline-offset: 2px; }

.mobile-toggle{
  display:none;
  border:1px solid var(--cul-border);
  background:#fff;
  padding:.55rem .7rem;
  border-radius: 10px;
  font-weight:700;
}
@media (max-width: 860px){
  .mobile-toggle{display:inline-flex}
  .primary-nav{display:none}
  .primary-nav.is-open{display:block}
  .primary-nav ul{
    flex-direction:column;
    align-items:stretch;
    padding:.75rem;
    background:#fff;
    border:1px solid var(--cul-border);
    border-radius: 14px;
    box-shadow: var(--cul-shadow);
    position:absolute;
    right: 1rem;
    top: 68px;
    width: min(92vw, 320px);
  }
  .primary-nav a{border-radius: 12px}
}

.site-main{
  padding: 2.25rem 0 3rem;
}

.section{
  padding: 1.9rem 0;
}
.card{
  background:#fff;
  border:1px solid var(--cul-border);
  border-radius: var(--cul-radius);
  box-shadow: var(--cul-shadow);
}
.card.pad{ padding: 1.25rem; }

.grid{
  display:grid;
  gap: 1rem;
}
.grid.two{ grid-template-columns: repeat(2, minmax(0,1fr)); }
.grid.three{ grid-template-columns: repeat(3, minmax(0,1fr)); }
@media (max-width: 860px){
  .grid.two, .grid.three{ grid-template-columns: 1fr; }
}

.kicker{
  color: var(--cul-gray);
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  font-size: .82rem;
}
.h1{
  font-size: clamp(1.8rem, 2.8vw, 2.6rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: .5rem 0 1rem;
}
.lede{
  color: var(--cul-gray);
  font-size: 1.05rem;
  max-width: 70ch;
}

.post-meta{
  color: var(--cul-gray);
  font-size: .92rem;
}
.post-meta a{color: var(--cul-gray)}
.post-meta a:hover{color: var(--cul-blue)}

.post-list .post-item{
  padding: 1rem;
  border: 1px solid var(--cul-border);
  border-radius: var(--cul-radius);
  background:#fff;
}
.post-list .post-item h3{
  margin:.2rem 0 .4rem;
  font-size: 1.15rem;
  line-height: 1.25;
}
.post-list .post-item p{margin:0; color: var(--cul-gray)}
.badge{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.25rem .55rem;
  border-radius: 999px;
  background: rgba(11,45,77,.08);
  color: var(--cul-ink);
  font-size:.78rem;
  font-weight:700;
}

.single-content{
  font-size: 1.05rem;
}
.single-content .wp-block-image{
  margin: 1.5rem 0;
}
.single-content h2, .single-content h3{ margin-top: 2rem; }

.author-box{
  margin-top: 2.25rem;
  padding: 1.15rem;
  border: 1px solid var(--cul-border);
  border-radius: var(--cul-radius);
  background: var(--cul-surface);
  display:flex;
  gap: 1rem;
  align-items:flex-start;
}
.author-box img.avatar{
  border-radius: 999px;
  width: 64px;
  height: 64px;
}
.author-box .author-name{
  font-weight: 800;
  margin: 0;
}
.author-box .author-bio{
  margin: .25rem 0 .65rem;
  color: var(--cul-gray);
}
.author-links{
  display:flex;
  gap:.75rem;
  flex-wrap: wrap;
  align-items:center;
}
.author-links a{
  font-weight: 700;
  color: var(--cul-blue);
}
.author-cta{
  margin-left:auto;
}
.author-cta a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.55rem .85rem;
  border-radius: 999px;
  background:#fff;
  border:1px solid var(--cul-border);
  font-weight: 800;
}
.author-cta a:hover{ text-decoration:none; border-color: rgba(70,88,112,.40); }

.pagination{
  margin-top: 1.75rem;
  display:flex;
  gap:.5rem;
  flex-wrap: wrap;
}
.pagination .page-numbers{
  padding:.45rem .7rem;
  border:1px solid var(--cul-border);
  border-radius: 10px;
}
.pagination .current{
  background: rgba(70,88,112,.14);
  border-color: rgba(70,88,112,.28);
}

.site-footer{
  border-top: 1px solid var(--cul-border);
  background: #fff;
}
.footer-inner{
  padding: 1.4rem 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  flex-wrap: wrap;
  color: var(--cul-gray);
  font-size: .95rem;
}
.footer-links{
  display:flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.footer-links a{ color: var(--cul-gray); font-weight: 700; }
.footer-links a:hover{ color: var(--cul-blue); text-decoration:none; }

/* WPForms basic styling */
.wpforms-container .wpforms-field input[type=text],
.wpforms-container .wpforms-field input[type=email],
.wpforms-container .wpforms-field textarea{
  width:100%;
  border:1px solid var(--cul-border);
  border-radius: 12px;
  padding:.7rem .8rem;
  font-size: 1rem;
}
.wpforms-container .wpforms-submit{
  background: var(--cul-accent) !important;
  border: 1px solid rgba(0,0,0,.06) !important;
  color: #fff !important;
  padding: .65rem 1rem !important;
  border-radius: 999px !important;
  font-weight: 800 !important;
  box-shadow: none !important;
}
.wpforms-container .wpforms-submit:hover{ filter: brightness(.98); }

/* Category and Tags styling */
.post-cats a,
.post-tags a{
  color: var(--cul-gray);
  font-weight: 700;
}
.post-cats a:hover,
.post-tags a:hover{
  color: var(--cul-blue);
  text-decoration: none;
}

/* Featured image styling */
.post-featured{
  margin: 1.25rem 0 1.75rem;
}
.post-featured img{
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--cul-radius);
  border: 1px solid var(--cul-border);
}
.card-thumb{
  display:block;
  width:100%;
  height: 160px; /* adjust to taste */
  overflow:hidden;
  border-radius: var(--cul-radius);
  border: 1px solid var(--cul-border);
  margin-bottom: .75rem;
}
.card-thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  object-position: center 40%; /* middle crop */
  display:block;
}
