/*
 Theme Name:   Can I Sue Now Child Theme
 Theme URI:    https://canisuenow.com
 Description:  GeneratePress child theme for Can I Sue Now? legal blog - Vox-style design
 Author:       Can I Sue Now
 Author URI:   https://canisuenow.com
 Template:     generatepress
 Version:      1.1.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  canisuenow
*/

/* ==========================================================================
   GeneratePress Container Overrides
   Remove default margins/padding on front page for full-width hero
   ========================================================================== */

/* Front page - full width, no container margins */
.home .site-main,
.home.page .site-main,
body.home .separate-containers .site-main {
  margin: 0;
  padding: 0;
}

/* Remove GeneratePress container padding on front page */
.home .inside-article,
.home.page .inside-article {
  padding: 0;
}

/* Ensure hero section bleeds to edges */
.home .site-main > .site-main,
.home #primary {
  max-width: 100%;
  margin: 0;
  padding: 0;
}

/* ==========================================================================
   Single Post Mobile Fixes
   Fix GeneratePress container issues on mobile for single posts
   ========================================================================== */

/* Single posts - clean up GeneratePress container on mobile */
@media (max-width: 768px) {
  .single .separate-containers .site-main {
    margin: 0;
  }

  .single .inside-article {
    padding: 0;
  }

  /* Ensure content doesn't overflow */
  .single .site-main,
  .single #primary {
    max-width: 100%;
    overflow-x: hidden;
  }

  /* Fix k-container padding on mobile */
  .single .k-container {
    padding-left: var(--k-site-padding);
    padding-right: var(--k-site-padding);
  }
}

/* ==========================================================================
   Theme-Specific Overrides
   Uses CSS variables from kahunam.css
   ========================================================================== */

/* Override GeneratePress defaults to use our typography */
body {
  font-family: var(--k-font-body);
  color: var(--color-text);
  line-height: var(--k-lh-relaxed);
}

h1, h2, h3, h4, h5, h6,
.entry-title,
.page-title,
.archive-title {
  font-family: var(--k-font-heading);
  color: var(--color-primary);
}

/* ==========================================================================
   Links
   ========================================================================== */

a {
  color: var(--color-secondary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-primary);
}

/* Keep white links white on hover (hero section) with subtle dim */
.k-bg-dark a.k-text-white:hover {
  color: rgba(255, 255, 255, 0.85);
}

/* ==========================================================================
   Entry/Article Styles (GeneratePress overrides)
   ========================================================================== */

.entry-title {
  font-size: var(--k-text-h1);
  line-height: var(--k-lh-tight);
  letter-spacing: var(--k-tracking-tight);
  margin-bottom: var(--k-space-4);
}

.entry-meta {
  font-family: var(--k-font-body);
  font-size: var(--k-text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--k-space-6);
}

.entry-content {
  font-family: var(--font-article);
  font-size: var(--k-text-lg);
  line-height: var(--k-lh-relaxed);
}

.entry-content p {
  margin-bottom: var(--k-space-5);
}

.entry-content h2 {
  font-size: var(--k-text-h2);
  margin-top: var(--k-space-7);
  margin-bottom: var(--k-space-4);
}

.entry-content h3 {
  font-size: var(--k-text-h3);
  margin-top: var(--k-space-6);
  margin-bottom: var(--k-space-2);
}

/* ==========================================================================
   Legal Disclaimer Styles (Theme-specific)
   ========================================================================== */

.legal-disclaimer {
  background-color: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: var(--k-border-radius-md);
  padding: var(--k-space-5);
  margin: var(--k-space-7) 0;
  font-family: var(--k-font-body);
  font-size: var(--k-text-sm);
}

.legal-disclaimer strong {
  color: #856404;
  display: block;
  margin-bottom: var(--k-space-1);
}

/* ==========================================================================
   Call to Action Box
   ========================================================================== */

.cta-box {
  background-color: var(--color-primary);
  color: #ffffff;
  padding: var(--k-space-6);
  border-radius: var(--k-border-radius-md);
  margin: var(--k-space-7) 0;
  text-align: center;
}

.cta-box h3 {
  color: #ffffff;
  font-family: var(--k-font-heading);
  margin-bottom: var(--k-space-4);
}

.cta-box .button {
  background-color: var(--color-secondary);
  color: #ffffff;
  padding: var(--k-space-4) var(--k-space-6);
  border-radius: var(--k-border-radius-sm);
  display: inline-block;
  font-family: var(--k-font-body);
  font-weight: 600;
  text-decoration: none;
  transition: background-color var(--transition-fast);
}

.cta-box .button:hover {
  background-color: #c41b1b;
  color: #ffffff;
}

/* ==========================================================================
   Custom Header Styles
   ========================================================================== */

.cisn-header {
  background-color: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 100;
}

.cisn-header-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--k-space-4) var(--k-site-padding);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cisn-logo img {
  height: 30px;
  width: auto;
}

.cisn-main-nav {
  flex: 1;
  display: flex;
  justify-content: flex-end;
}

.cisn-nav-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: var(--k-gap-1);
}

.cisn-nav-menu li a {
  font-family: var(--k-font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text);
  padding-block: var(--k-space-2);
  position: relative;
  text-decoration: none;
}

.cisn-nav-menu li a:hover {
  color: var(--color-text); /* Keep same color - underline provides the hover feedback */
}

/* ==========================================================================
   Underline Link Animation (Desktop Only)
   CSS-based underline animation on hover
   ========================================================================== */

[data-underline-link] {
  text-decoration: none;
  position: relative;
}

[data-underline-link]::before {
  content: "";
  position: absolute;
  bottom: -0.0625em;
  left: 0;
  width: 100%;
  height: 0.0625em;
  background-color: currentColor;
  transition: transform 0.735s cubic-bezier(0.625, 0.05, 0, 1);
  transform-origin: right;
  transform: scaleX(0) rotate(0.001deg);
}

@media (hover: hover) and (pointer: fine) {
  [data-underline-link]:hover::before {
    transform-origin: left;
    transform: scaleX(1) rotate(0.001deg);
  }
}

/* Mobile Header - Hide desktop nav */
@media (max-width: 768px) {
  .cisn-main-nav {
    display: none;
  }
}

/* ==========================================================================
   Custom Footer Styles
   ========================================================================== */

.cisn-footer {
  background-color: var(--color-bg-dark);
  color: #e2e8f0;
}

.cisn-footer-main {
  padding-block: var(--k-section-sm);
}

.cisn-footer-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--k-gap-5);
}

.cisn-footer-brand {
  padding-right: var(--k-space-6);
}

.cisn-footer-logo img {
  height: 28px;
  width: auto;
  margin-bottom: var(--k-space-4);
  filter: invert(1);
}

.cisn-footer-tagline {
  font-family: var(--k-font-body);
  font-size: var(--k-text-sm);
  line-height: var(--k-lh-relaxed);
  color: #a0aec0;
  margin: 0;
}

.cisn-footer-menu h4 {
  font-family: var(--k-font-body);
  color: #ffffff;
  font-size: var(--k-text-sm);
  font-weight: 700;
  margin: 0 0 var(--k-space-4);
  text-transform: uppercase;
  letter-spacing: var(--k-tracking-wider);
}

.cisn-footer-nav {
  list-style: none;
  margin: 0;
  padding: 0;
}

.cisn-footer-nav li {
  margin-bottom: var(--k-space-2);
}

.cisn-footer-nav li a {
  font-family: var(--k-font-body);
  color: #a0aec0;
  font-size: var(--k-text-sm);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.cisn-footer-nav li a:hover {
  color: #ffffff;
}

.cisn-footer-bottom {
  background-color: #111111;
  padding-block: var(--k-space-5);
}

.cisn-footer-bottom .cisn-footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--k-gap-2);
}

.cisn-copyright {
  font-family: var(--k-font-body);
  margin: 0;
  font-size: var(--k-text-sm);
  color: #a0aec0;
}

.cisn-disclaimer {
  font-family: var(--k-font-body);
  margin: 0;
  font-size: var(--k-text-xs);
  color: #718096;
  font-style: italic;
}

/* ==========================================================================
   Footer Categories Grid
   ========================================================================== */

.cisn-footer-categories {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-block: var(--k-space-6);
}

.cisn-footer-categories h4 {
  font-family: var(--k-font-body);
  color: #ffffff;
  font-size: var(--k-text-sm);
  font-weight: 700;
  margin: 0 0 var(--k-space-4);
  text-transform: uppercase;
  letter-spacing: var(--k-tracking-wider);
}

.cisn-footer-categories-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--k-gap-2) var(--k-gap-4);
}

.cisn-footer-categories-grid li a {
  font-family: var(--k-font-body);
  color: #a0aec0;
  font-size: var(--k-text-sm);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.cisn-footer-categories-grid li a:hover {
  color: #ffffff;
}

.cisn-cat-count {
  color: #718096;
  font-size: var(--k-text-xs);
}

/* Mobile Footer */
@media (max-width: 768px) {
  .cisn-footer-inner {
    grid-template-columns: 1fr;
    gap: var(--k-gap-4);
  }

  .cisn-footer-brand {
    padding-right: 0;
  }

  .cisn-footer-bottom .cisn-footer-inner {
    flex-direction: column;
    text-align: center;
  }

  .cisn-footer-categories-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ==========================================================================
   Site Title (fallback when no logo)
   ========================================================================== */

.cisn-site-title {
  font-family: var(--k-font-heading);
  font-size: var(--k-text-h4);
  font-weight: 700;
  color: var(--color-primary);
}

/* ==========================================================================
   Header Search Trigger
   ========================================================================== */

.cisn-search-trigger {
  display: flex;
  align-items: center;
  gap: var(--k-space-2);
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--k-border-radius-md);
  padding: var(--k-space-1) var(--k-space-4);
  font-family: var(--k-font-body);
  font-size: var(--k-text-sm);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: border-color 0.15s ease, color 0.15s ease;
  margin-left: calc(-1 * var(--k-space-2));
}

.cisn-search-trigger:hover {
  border-color: var(--color-text-muted);
  color: var(--color-text);
}

.cisn-search-trigger svg {
  flex-shrink: 0;
}

.cisn-search-trigger kbd {
  font-family: var(--k-font-body);
  font-size: 11px;
  background-color: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--k-border-radius-sm);
  padding: 2px 6px;
}

@media (max-width: 768px) {
  .cisn-search-trigger-text,
  .cisn-search-trigger kbd {
    display: none;
  }

  .cisn-search-trigger {
    padding: var(--k-space-2);
    margin-left: auto;
    margin-right: var(--k-space-2);
  }
}

/* ==========================================================================
   Mobile Menu - Hamburger Button
   ========================================================================== */

.cisn-mobile-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--k-space-2);
  z-index: 1001;
}

.hamburger-box {
  width: 24px;
  height: 18px;
  display: inline-block;
  position: relative;
}

.hamburger-inner,
.hamburger-inner::before,
.hamburger-inner::after {
  width: 24px;
  height: 2px;
  background-color: var(--color-text);
  border-radius: 2px;
  position: absolute;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.hamburger-inner {
  top: 50%;
  transform: translateY(-50%);
}

.hamburger-inner::before,
.hamburger-inner::after {
  content: '';
  display: block;
}

.hamburger-inner::before {
  top: -7px;
}

.hamburger-inner::after {
  bottom: -7px;
}

/* Hamburger active state - X animation */
.cisn-mobile-toggle.is-active .hamburger-inner {
  transform: translateY(-50%) rotate(45deg);
}

.cisn-mobile-toggle.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
}

.cisn-mobile-toggle.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(-90deg);
}

/* ==========================================================================
   Mobile Menu - Overlay
   ========================================================================== */

.cisn-mobile-menu {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-bg);
  z-index: 1000;
  overflow-y: auto;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.cisn-mobile-menu.is-active {
  opacity: 1;
  visibility: visible;
}

.cisn-mobile-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--k-space-4) var(--k-site-padding);
  border-bottom: 1px solid var(--color-border);
}

.cisn-mobile-logo img {
  height: 30px;
  width: auto;
}

/* Close button in mobile menu */
.cisn-mobile-close {
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--k-space-2);
  color: var(--color-text);
  transition: color 0.2s ease;
}

.cisn-mobile-close:hover {
  color: var(--color-secondary);
}

.cisn-mobile-close svg {
  display: block;
  width: 24px;
  height: 24px;
}

.cisn-mobile-nav {
  padding: var(--k-space-5) var(--k-site-padding);
}

.cisn-mobile-nav-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

.cisn-mobile-nav-menu li {
  border-bottom: 1px solid var(--color-border);
}

.cisn-mobile-nav-menu li:last-child {
  border-bottom: none;
}

.cisn-mobile-nav-menu li a {
  display: block;
  padding-block: var(--k-space-4);
  font-family: var(--k-font-heading);
  font-size: var(--k-text-h4);
  font-weight: 600;
  color: var(--color-primary);
  text-decoration: none;
  transition: color 0.2s ease, background-color 0.2s ease;
}

.cisn-mobile-nav-menu li a:hover,
.cisn-mobile-nav-menu li a:focus {
  color: var(--color-secondary);
}

.cisn-mobile-nav-menu li.current-menu-item a {
  color: var(--color-secondary);
}

/* Prevent body scroll when menu is open */
body.mobile-menu-open {
  overflow: hidden;
}

/* ==========================================================================
   Mobile Responsive - Show hamburger, hide desktop nav
   ========================================================================== */

@media (max-width: 768px) {
  .cisn-main-nav {
    display: none;
  }

  .cisn-mobile-toggle {
    display: block;
  }

  .cisn-mobile-menu {
    display: block;
  }
}

/* ==========================================================================
   Single Post Header Tags
   ========================================================================== */

.cisn-article-tags-top {
  display: flex;
  align-items: center;
  gap: var(--k-gap-2);
  margin-bottom: var(--k-space-4);
}

.cisn-article-header__region {
  font-family: var(--k-font-body);
  font-size: var(--k-text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--k-tracking-wider);
  color: var(--color-text-muted);
  padding: var(--k-space-1) var(--k-space-2);
  background-color: var(--color-bg-alt);
  border-radius: var(--k-border-radius-sm);
}

.cisn-article-meta__updated {
  font-style: italic;
  color: var(--color-text-muted);
}

/* ==========================================================================
   Sidebar Disclaimer Override
   ========================================================================== */

.cisn-sidebar-disclaimer .cisn-legal-disclaimer {
  background-color: #fff3cd;
  border: 1px solid #ffc107;
}

/* ==========================================================================
   More Stories Grid - 4 columns on desktop
   ========================================================================== */

.cisn-more-stories__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--k-gap-4);
}

@media (max-width: 1024px) {
  .cisn-more-stories__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .cisn-more-stories__grid {
    grid-template-columns: 1fr;
  }
}

