/* ── Google Fonts: Cormorant Garamond (display) + DM Sans (body) ── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300;1,9..40,400&display=swap');

/* ── CSS Variables (ImpromptuIndian brand — mockup palette) ── */
:root {
  --ii-red: #A52422;
  --ii-maroon: #7F3937;
  --ii-grey: #7A7D7D;
  --ii-white: #FFFFFF;
  --ii-black: #000000;
  --ii-red-light: rgba(165, 36, 34, 0.08);
  --ii-red-glow: rgba(165, 36, 34, 0.22);

  --gold: var(--ii-red);
  --gold-light: #D46462;
  --gold-pale: var(--ii-red-light);
  --blue: var(--ii-red);
  --blue-dark: var(--ii-maroon);
  --navy: #141414;
  --ink: var(--ii-black);
  --ink-muted: var(--ii-grey);
  --ink-faint: rgba(122, 125, 125, 0.85);
  --surface: #FFFFFF;
  --surface-off: #F7F6F4;
  --surface-warm: #EFEFED;
  --border: rgba(122, 125, 125, 0.18);
  --border-gold: rgba(165, 36, 34, 0.28);
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --shadow-card: 0 1px 3px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.06);
  --shadow-hover: 0 4px 8px rgba(0,0,0,0.04), 0 24px 48px rgba(0,0,0,0.11);
  --transition: 0.38s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ── Scroll Progress Bar ── */
#scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--ii-maroon), var(--ii-red));
  z-index: 9999;
  width: 0%;
  transition: width 0.08s linear;
  pointer-events: none;
}

/* ── Base & scrollbar (hidden, scroll still works) ── */
html {
  scroll-behavior: smooth;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar {
  display: none;
}

body {
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink);
  background: var(--surface-off);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

::selection { background: var(--ii-red-light); color: var(--ink); }

/* ── Header (legacy pages only — not marketing nav) ── */
header:not(.marketing-nav-header) {
  background: var(--ii-white) !important;
  border-bottom: 1px solid var(--border);
  color: var(--ii-black) !important;
  box-shadow: 0 1px 8px rgba(0, 0, 0, 0.04);
}

header:not(.marketing-nav-header) .text-\[\#FFCC00\],
header:not(.marketing-nav-header) .text-\[\#1273EB\],
header:not(.marketing-nav-header) .text-\[\#A52422\],
header:not(.marketing-nav-header) .text-white {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.4rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em !important;
  color: var(--ii-black) !important;
}

header:not(.marketing-nav-header) i[data-lucide="shirt"],
header:not(.marketing-nav-header) .text-\[\#A52422\].w-6 {
  color: var(--ii-red) !important;
}

header:not(.marketing-nav-header) #menu-btn i,
header:not(.marketing-nav-header) #menu-btn {
  color: var(--ii-black) !important;
}

header:not(.marketing-nav-header) nav a {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ii-black) !important;
  transition: color 0.2s ease, opacity 0.2s ease;
}

header:not(.marketing-nav-header) nav a:hover {
  color: var(--ii-grey) !important;
}

header:not(.marketing-nav-header) nav a.font-bold,
header:not(.marketing-nav-header) nav a.underline {
  font-weight: 700 !important;
  color: var(--ii-black) !important;
}

/* Header auth — compact, matches about/index nav buttons */
header:not(.marketing-nav-header) .header-auth {
  gap: 0.75rem;
}

header:not(.marketing-nav-header) .header-login,
header:not(.marketing-nav-header) a[href="/login"].header-login {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;
  color: var(--ii-black) !important;
  line-height: 1.25 !important;
}

header:not(.marketing-nav-header) .header-login:hover,
header:not(.marketing-nav-header) a[href="/login"].header-login:hover {
  color: var(--ii-grey) !important;
}

header:not(.marketing-nav-header) .header-signup,
header:not(.marketing-nav-header) a[href="/register"],
header:not(.marketing-nav-header) .blog-signup-btn {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em !important;
  line-height: 1.25 !important;
  padding: 0.375rem 0.75rem !important;
  background: var(--ii-red) !important;
  color: var(--ii-white) !important;
  border-radius: 6px !important;
  box-shadow: none !important;
}

header:not(.marketing-nav-header) .header-signup:hover,
header:not(.marketing-nav-header) a[href="/register"]:hover,
header:not(.marketing-nav-header) .blog-signup-btn:hover {
  background: var(--ii-maroon) !important;
}

#mobile-menu .header-login,
#mobile-menu .header-signup {
  font-size: 0.875rem !important;
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

#mobile-menu {
  background: var(--ii-white) !important;
  border-top: 1px solid var(--border) !important;
  color: var(--ii-black) !important;
}

#mobile-menu a {
  color: var(--ii-black) !important;
}

#mobile-menu a:hover {
  background: var(--ii-red-light) !important;
}

/* ── Hero (white + grid, maroon quote, black type) ── */
#blog-listing > section:first-child {
  background: var(--ii-white) !important;
  padding: 7rem 0 6rem !important;
  position: relative;
  overflow: hidden;
  color: var(--ii-black) !important;
}

#blog-listing > section:first-child::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 56px, rgba(0,0,0,0.025) 56px, rgba(0,0,0,0.025) 57px),
    repeating-linear-gradient(90deg, transparent, transparent 56px, rgba(0,0,0,0.025) 56px, rgba(0,0,0,0.025) 57px);
  pointer-events: none;
}

#blog-listing > section:first-child::after {
  content: '\201C';
  position: absolute;
  right: 5%;
  top: -0.15em;
  font-family: 'Cormorant Garamond', serif;
  font-size: 26rem;
  line-height: 1;
  color: rgba(165, 36, 34, 0.12);
  pointer-events: none;
  user-select: none;
}

#blog-listing > section:first-child h1 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(3rem, 6.5vw, 5.75rem) !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.05 !important;
  color: var(--ii-black) !important;
}

#blog-listing > section:first-child p {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 1.0625rem !important;
  font-weight: 300 !important;
  color: var(--ii-grey) !important;
  letter-spacing: 0.01em !important;
}

#blog-listing > section:first-child > div > p.animate-fadeUp {
  color: var(--ii-black) !important;
  opacity: 0.55;
}

#blog-listing > section:first-child form {
  background: var(--ii-white) !important;
  border-radius: 60px !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06) !important;
  border: 1px solid var(--border) !important;
  overflow: hidden;
  padding: 5px !important;
}

#blog-listing > section:first-child form input {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.9375rem;
  color: var(--ink);
  background: transparent;
  padding: 0.5rem 1rem;
}

#blog-listing > section:first-child form button {
  background: var(--ii-red) !important;
  color: var(--ii-white) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  border-radius: 60px !important;
  padding: 0.65rem 1.75rem !important;
  transition: all 0.22s ease !important;
}

#blog-listing > section:first-child form button:hover {
  background: var(--ii-maroon) !important;
  color: var(--ii-white) !important;
}

/* ── Article listings section ── */
#blog-listing > section:last-child {
  background: var(--surface-off) !important;
  padding: 5rem 0 !important;
}

/* "All Articles" heading */
#blog-listing h2.text-2xl {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 2.125rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.015em !important;
  color: var(--ink) !important;
}

/* Search bar */
.flex.items-center.bg-white.border.border-gray-200.rounded-lg {
  border-radius: var(--radius-md) !important;
  border-color: var(--border) !important;
  box-shadow: var(--shadow-card) !important;
  transition: box-shadow 0.22s ease, border-color 0.22s ease;
}
.flex.items-center.bg-white.border.border-gray-200.rounded-lg:focus-within {
  border-color: var(--border-gold) !important;
  box-shadow: 0 0 0 3px var(--ii-red-light), var(--shadow-card) !important;
}

#blog-search, #blog-sort {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.875rem;
}

#blog-search-btn {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
}

/* ── Sidebar ── */
#blog-listing aside {
  position: sticky;
  top: 88px;
  align-self: start;
}

#blog-listing aside > div,
.sidebar-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1.125rem;
  box-shadow: var(--shadow-card);
}

#blog-listing aside h3 {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--ink-faint) !important;
  margin-bottom: 0.875rem;
}

/* Category chips */
.cat-chip {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--ink);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.18s ease;
  text-align: left;
}

.cat-chip::after {
  content: '→';
  font-size: 0.75rem;
  opacity: 0.28;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.cat-chip:hover {
  background: var(--gold-pale);
  border-color: var(--border-gold);
  color: var(--ii-maroon);
  transform: translateX(2px);
}
.cat-chip:hover::after { opacity: 0.65; transform: translateX(3px); }

.cat-chip.active {
  background: var(--ii-red);
  color: var(--ii-white);
  border-color: var(--ii-red);
  box-shadow: 0 4px 14px var(--ii-red-glow);
}
.cat-chip.active::after { color: var(--ii-white); opacity: 0.55; }
.cat-chip.active:hover { background: var(--ii-maroon); transform: translateX(2px); }

/* Tag + Type chips */
.tag-chip, .type-chip {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.78rem;
  font-weight: 500;
  padding: 5px 13px;
  border-radius: 60px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--ink-muted);
  cursor: pointer;
  transition: all 0.18s ease;
  letter-spacing: 0.01em;
}

.tag-chip:hover, .type-chip:hover {
  border-color: var(--border-gold);
  color: var(--ii-maroon);
  background: var(--gold-pale);
}

.tag-chip.active, .type-chip.active {
  background: var(--ii-red);
  color: var(--ii-white);
  border-color: var(--ii-red);
  font-weight: 600;
  box-shadow: 0 2px 8px var(--ii-red-glow);
}

.cat-chip.is-disabled, .tag-chip.is-disabled, .type-chip.is-disabled,
.cat-chip:disabled, .tag-chip:disabled, .type-chip:disabled {
  opacity: 0.42;
  cursor: not-allowed;
  transform: none !important;
}

/* Sidebar links */
.sidebar-link {
  display: block;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface-off);
  text-decoration: none;
  transition: all 0.2s ease;
}
.sidebar-link:hover {
  border-color: var(--border-gold);
  background: var(--gold-pale);
  transform: translateX(3px);
}

.sidebar-link-title {
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--ink);
  line-height: 1.3;
}
.sidebar-link-meta {
  margin-top: 3px;
  font-size: 0.73rem;
  color: var(--ink-faint);
  letter-spacing: 0.02em;
}

/* ── Featured Post ── */
#featured-post > div {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xl) !important;
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--transition), transform var(--transition), border-color 0.25s ease;
  background: var(--surface);
  position: relative;
}
#featured-post > div::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--ii-maroon), var(--ii-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.45s cubic-bezier(0.25,0.46,0.45,0.94);
}
#featured-post > div:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-5px);
  border-color: rgba(165, 36, 34,0.22);
}
#featured-post > div:hover::after { transform: scaleX(1); }

#featured-post img {
  transition: transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94);
}
#featured-post > div:hover img { transform: scale(1.05); }

#featured-post .text-xs.font-bold {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
}

#featured-post h2 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.875rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: var(--ink) !important;
  line-height: 1.18 !important;
}

#featured-post p {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.9375rem;
  font-weight: 300;
  color: var(--ink-muted) !important;
}

#featured-post a {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: gap 0.22s ease;
}
#featured-post a:hover { gap: 9px; }

/* ── Blog Cards ── */
#blog-grid article {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--transition), transform var(--transition), border-color 0.22s ease;
  position: relative;
}
#blog-grid article::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--ii-maroon), var(--ii-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}
#blog-grid article:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-7px);
  border-color: rgba(165, 36, 34,0.18);
}
#blog-grid article:hover::after { transform: scaleX(1); }

#blog-grid article img {
  transition: transform 0.65s cubic-bezier(0.25,0.46,0.45,0.94);
  min-height: 176px;
  background: var(--surface-warm);
}
#blog-grid article:hover img { transform: scale(1.07); }

/* Category badge */
#blog-grid article .absolute.top-2 {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.58rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  background: rgba(255,255,255,0.96) !important;
  color: var(--ink) !important;
  border-radius: 4px;
  padding: 3px 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.10);
  border: 1px solid rgba(0,0,0,0.06);
}

#blog-grid article .text-xs {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.67rem !important;
  letter-spacing: 0.05em !important;
  color: var(--ink-faint) !important;
}

#blog-grid article h3 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  line-height: 1.28 !important;
  letter-spacing: -0.005em !important;
  color: var(--ink) !important;
  transition: color 0.2s ease;
}
#blog-grid article:hover h3 { color: var(--ii-red) !important; }

#blog-grid article p.text-sm {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 300 !important;
  color: var(--ink-muted) !important;
  line-height: 1.6 !important;
}

#blog-grid article a {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  transition: gap 0.2s ease, color 0.2s ease;
}
#blog-grid article:hover a { gap: 7px; color: var(--ii-maroon) !important; }

/* ── Load More ── */
#load-more-btn {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  border: 1px solid var(--border-gold) !important;
  color: var(--gold) !important;
  background: transparent !important;
  border-radius: 60px !important;
  padding: 0.75rem 2.75rem !important;
  transition: all 0.28s ease !important;
  position: relative;
  overflow: hidden;
}
#load-more-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gold);
  transform: translateY(102%);
  transition: transform 0.32s ease;
}
#load-more-btn:hover { color: var(--ii-white) !important; }
#load-more-btn:hover::before { transform: translateY(0); }
#load-more-btn, #load-more-btn span { position: relative; z-index: 1; }

/* ── Article Detail ── */
#blog-details-view section {
  background: var(--surface-off) !important;
}

#dynamic-category {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
}

#dynamic-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(2.25rem, 4.5vw, 3.75rem) !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.08 !important;
  color: var(--ink) !important;
}

#dynamic-cover {
  border-radius: var(--radius-xl);
}

.article-content span.text-\[\#1273EB\],
.article-content span.text-\[\#A52422\] {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
}
.article-content h1 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(2rem, 4vw, 3.25rem) !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.1 !important;
}

/* Share buttons */
#copyLinkBtn, #shareXBtn {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  border-radius: 60px;
  border: 1px solid var(--border);
  transition: all 0.22s ease;
}
#copyLinkBtn:hover { background: var(--gold-pale); border-color: var(--border-gold); color: var(--ii-red); }
#shareXBtn:hover { background: var(--ii-red); border-color: var(--ii-red); color: #fff; }

/* Related posts title */
#blog-details-view h3.text-xl {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.875rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: var(--ink) !important;
}

/* Back link */
#blog-details-view a[href="#"] {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-muted);
  transition: color 0.2s ease, gap 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
#blog-details-view a[href="#"]:hover { color: var(--gold); }

/* ── Prose (article content) ── */
.prose {
  max-width: 800px;
  margin: 0 auto;
  font-family: 'DM Sans', sans-serif;
  font-size: 1.0625rem;
  line-height: 1.82;
  color: var(--ink-muted);
  font-weight: 300;
}

.prose p { margin: 0 0 1.2rem; }
.prose p:empty, .prose p > br:only-child { display: none; }

.prose .lead,
.prose p.lead {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.55;
  color: var(--ink);
  font-style: italic;
  border-left: 3px solid var(--gold);
  padding-left: 1.25rem;
  margin-bottom: 2rem;
}

.prose h1 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.5rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.12;
  color: var(--ink);
  margin: 2.5rem 0 1rem;
}

.prose h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.875rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--ink);
  margin: 2.5rem 0 0.875rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}

.prose h3 {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--ink);
  margin: 2rem 0 0.625rem;
}

.prose strong { font-weight: 600; color: var(--ink); }

.prose ul {
  list-style: none;
  padding-left: 0;
  margin: 0 0 1.5rem;
}
.prose ul li {
  padding-left: 1.25rem;
  position: relative;
  margin-bottom: 0.5rem;
}
.prose ul li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--gold);
  font-weight: 600;
}

.prose a { color: var(--blue); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.prose img { border-radius: var(--radius-lg); margin: 2rem 0; }

.prose img.ii-img-left  { float:left; margin:0.5rem 1.5rem 1rem 0; max-width:min(52%,520px); height:auto; }
.prose img.ii-img-right { float:right; margin:0.5rem 0 1rem 1.5rem; max-width:min(52%,520px); height:auto; }
.prose img.ii-img-center { display:block; float:none; clear:both; margin:1.5rem auto; max-width:100%; height:auto; }
.prose::after { content:''; display:block; clear:both; }

.prose blockquote {
  border-left: 3px solid var(--gold);
  padding: 1rem 1.5rem;
  background: var(--gold-pale);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  color: var(--ink);
  font-style: italic;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.25rem;
  line-height: 1.5;
  margin: 2rem 0;
}

.prose code { background: rgba(17,24,39,0.06); padding:0.15rem 0.4rem; border-radius:4px; font-size:0.9em; }
.prose pre { background: var(--navy); color:#e5e7eb; padding:1.25rem; border-radius:var(--radius-md); overflow-x:auto; margin:1.75rem 0; }

.prose table { width:100%; border-collapse:collapse; margin:1.75rem 0; font-size:0.9375em; }
.prose th, .prose td { border:1px solid var(--border); padding:0.65rem 0.875rem; vertical-align:top; }
.prose th { background:var(--surface-warm); font-weight:600; font-family:'DM Sans',sans-serif; font-size:0.78rem; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-muted); }

/* ── CTA Section ── */
section.py-20.bg-gradient-to-br {
  background: linear-gradient(140deg, #0a0a0a 0%, var(--ii-maroon) 50%, var(--ii-red) 100%) !important;
  padding: 7rem 0 !important;
  position: relative;
  overflow: hidden;
}
section.py-20.bg-gradient-to-br::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(45deg, transparent, transparent 38px, rgba(165, 36, 34, 0.04) 38px, rgba(165, 36, 34, 0.04) 39px);
  pointer-events: none;
}
/* Remove default blobs from original */
section.py-20.bg-gradient-to-br .absolute { display: none !important; }

.cta-heading {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(2.25rem, 4.5vw, 3.5rem) !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.08 !important;
  animation: ctaFadeIn 1s ease-out forwards;
  animation-delay: 0.2s;
  opacity: 0;
}

.cta-text {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 300 !important;
  color: rgba(255,255,255,0.58) !important;
  letter-spacing: 0.01em !important;
  animation: ctaFadeIn 1s ease-out forwards;
  animation-delay: 0.4s;
  opacity: 0;
}

.cta-heading span.text-\[\#FFCC00\],
.cta-heading span.text-\[\#A52422\] {
  color: var(--gold-light) !important;
}

.cta-button {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  background: transparent !important;
  color: var(--ii-white) !important;
  border: 1.5px solid var(--ii-white) !important;
  border-radius: 60px !important;
  padding: 1rem 3.25rem !important;
  animation: ctaFadeIn 1s ease-out forwards;
  animation-delay: 0.6s;
  opacity: 0;
  position: relative;
  overflow: hidden;
  transition: color 0.32s ease !important;
  display: inline-block;
}
.cta-button::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--ii-white);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.38s cubic-bezier(0.25,0.46,0.45,0.94);
  z-index: 0;
}
.cta-button:hover { color: var(--ii-red) !important; }
.cta-button:hover::before { transform: scaleX(1); }
.cta-button span { position: relative; z-index: 1; }

/* ── Footer ── */
footer { background: var(--surface) !important; border-top: 1px solid var(--border) !important; }

footer h3 {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--ink-faint) !important;
}

footer a:hover { color: var(--ii-red) !important; }

footer .text-xl.font-bold span.text-\[\#1273EB\],
footer .text-xl.font-bold span.text-\[\#A52422\] {
  color: var(--ii-red) !important;
}

footer .text-xl.font-bold span.text-\[\#FFCC00\] {
  color: var(--ii-maroon) !important;
}

footer .text-xl.font-bold i[data-lucide="shirt"] {
  color: var(--ii-red) !important;
}

footer .text-xl.font-bold {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.4rem !important;
  font-weight: 600 !important;
}

footer p.text-gray-500,
footer .text-\[\#7A7D7D\] {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--ink-faint) !important;
}

footer ul a {
  color: var(--ii-grey);
  transition: color 0.2s ease;
}

footer ul a:hover {
  color: var(--ii-red) !important;
}

/* ── Animations ── */
@keyframes ctaFadeIn {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes slideUpFade {
  from { opacity:0; transform:translateY(34px) scale(0.97); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
@keyframes heroReveal {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes shimmer {
  0%   { background-position:200% 0; }
  100% { background-position:-200% 0; }
}

.animate-fadeUp {
  animation: heroReveal 0.95s cubic-bezier(0.16,1,0.3,1) forwards;
  opacity: 0;
}
.delay-200 { animation-delay:0.22s; }
.delay-400 { animation-delay:0.48s; }
.entry-animate { animation: slideUpFade 0.75s cubic-bezier(0.16,1,0.3,1) forwards; }
.article-fade-in { animation: slideUpFade 1s ease-out forwards; }

/* Skeleton */
.skeleton {
  background: linear-gradient(90deg,#ede9e0,#e4dfd4,#ede9e0);
  background-size: 200% 100%;
  animation: shimmer 1.4s ease-in-out infinite;
  border-radius: var(--radius-lg);
}

/* Clamp helpers */
.line-clamp-2 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}
.line-clamp-3 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  overflow: hidden;
}

/* Container */
.container { max-width:1200px; }

/* View transitions */
#blog-listing, #blog-details-view { transition:opacity 0.25s ease; }

/* Focus ring */
button:focus-visible, a:focus-visible, input:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--ii-red-glow);
}

/* Brand link utility (JS-rendered cards) */
.blog-link { color: var(--ii-red); font-weight: 600; text-decoration: none; }
.blog-link:hover { color: var(--ii-maroon); }
.group:hover .blog-link-title { color: var(--ii-red) !important; }

/* Sidebar subscribe */
.sidebar-card button[type="submit"] {
  background: var(--ii-red) !important;
  color: var(--ii-white) !important;
}
.sidebar-card button[type="submit"]:hover {
  background: var(--ii-maroon) !important;
}

.sidebar-card input:focus {
  border-color: var(--ii-red) !important;
  box-shadow: 0 0 0 3px var(--ii-red-light);
}

#blog-search-btn { color: var(--ii-red) !important; }

#load-more-btn:hover::before { background: var(--ii-red); }

/* Bg pattern fallback */
.bg-pattern {
  background-image: radial-gradient(rgba(0,0,0,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
}
