/* ════════════════════════════════════════════════════════════════════════════
   LuckyWP — Main stylesheet (Tailwind entry).
   Compiled to build/main.css.
   ════════════════════════════════════════════════════════════════════════════ */

*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

/* ! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com */

/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
  color: inherit;
  text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/

dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/

:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */

[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}

html { scroll-behavior: smooth; }

body {
  background-color: var(--lwpt-color-bg, #ffffff);
  font-family: var(--lwpt-font-body, Inter), system-ui, sans-serif;
  color: var(--lwpt-color-text, #0f172a);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
        font-size: 17px;
        line-height: 1.7;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--lwpt-font-heading, Inter), system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--lwpt-color-text, #0f172a); line-height: 1.25;
}

h1 { font-size: clamp(2rem, 4vw, 2.75rem); }

h2 { font-size: clamp(1.5rem, 3vw, 2rem); }

h3 { font-size: clamp(1.25rem, 2.4vw, 1.5rem); }

a {
  color: var(--lwpt-color-primary, #4f46e5);
}

a:hover {
  text-decoration-line: underline;
}

img, video, svg { max-width: 100%; height: auto; }

hr {
  margin-top: 2rem;
  margin-bottom: 2rem;
  border-top-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
}

:focus-visible {
        outline: 2px solid var(--lwpt-color-primary, #4f46e5);
        outline-offset: 2px;
        border-radius: 4px;
    }

body {
        font-family: var(--lwpt-font-body, Inter), system-ui, sans-serif;
        font-size: var(--lwpt-body-size, 17px);
        font-weight: var(--lwpt-body-weight, 400);
        line-height: var(--lwpt-body-line, 1.7);
        color: var(--lwpt-color-text, #0f172a);
        background: var(--lwpt-color-bg, #ffffff);
    }

h1, h2, h3, h4, h5, h6 {
        font-family: var(--lwpt-font-heading, Inter), system-ui, sans-serif;
        color: var(--lwpt-color-heading, var(--lwpt-color-text, #0f172a));
        font-weight: var(--lwpt-heading-weight, 800);
        letter-spacing: var(--lwpt-heading-tracking, -0.02em);
        line-height: var(--lwpt-heading-line, 1.25);
    }

h1 { font-size: clamp(1.9rem, 5vw, var(--lwpt-h1-size, 44px)); }

h2 { font-size: clamp(1.4rem, 3.5vw, var(--lwpt-h2-size, 32px)); margin-top: var(--lwpt-space-heading-top, 40px); }

h3 { font-size: clamp(1.15rem, 2.4vw, var(--lwpt-h3-size, 24px)); margin-top: calc(var(--lwpt-space-heading-top, 40px) * 0.75); }

p, ul, ol { margin-block: var(--lwpt-space-para-gap, 20px); }

a { color: var(--lwpt-color-link, var(--lwpt-color-primary, #4f46e5)); }

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

.container {
  width: 100%;
}

@media (min-width: 640px) {

  .container {
    max-width: 640px;
  }
}

@media (min-width: 768px) {

  .container {
    max-width: 768px;
  }
}

@media (min-width: 1024px) {

  .container {
    max-width: 1024px;
  }
}

@media (min-width: 1280px) {

  .container {
    max-width: 1280px;
  }
}

@media (min-width: 1536px) {

  .container {
    max-width: 1536px;
  }
}

.prose {
  color: var(--tw-prose-body);
  max-width: 65ch;
}

.prose :where(p):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 1.25em;
  margin-bottom: 1.25em;
}

.prose :where([class~="lead"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-lead);
  font-size: 1.25em;
  line-height: 1.6;
  margin-top: 1.2em;
  margin-bottom: 1.2em;
}

.prose :where(a):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-links);
  text-decoration: underline;
  font-weight: 500;
}

.prose :where(strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-bold);
  font-weight: 600;
}

.prose :where(a strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
}

.prose :where(blockquote strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
}

.prose :where(thead th strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
}

.prose :where(ol):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: decimal;
  margin-top: 1.25em;
  margin-bottom: 1.25em;
  padding-inline-start: 1.625em;
}

.prose :where(ol[type="A"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: upper-alpha;
}

.prose :where(ol[type="a"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: lower-alpha;
}

.prose :where(ol[type="A" s]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: upper-alpha;
}

.prose :where(ol[type="a" s]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: lower-alpha;
}

.prose :where(ol[type="I"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: upper-roman;
}

.prose :where(ol[type="i"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: lower-roman;
}

.prose :where(ol[type="I" s]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: upper-roman;
}

.prose :where(ol[type="i" s]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: lower-roman;
}

.prose :where(ol[type="1"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: decimal;
}

.prose :where(ul):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  list-style-type: disc;
  margin-top: 1.25em;
  margin-bottom: 1.25em;
  padding-inline-start: 1.625em;
}

.prose :where(ol > li):not(:where([class~="not-prose"],[class~="not-prose"] *))::marker {
  font-weight: 400;
  color: var(--tw-prose-counters);
}

.prose :where(ul > li):not(:where([class~="not-prose"],[class~="not-prose"] *))::marker {
  color: var(--tw-prose-bullets);
}

.prose :where(dt):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-headings);
  font-weight: 600;
  margin-top: 1.25em;
}

.prose :where(hr):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  border-color: var(--tw-prose-hr);
  border-top-width: 1px;
  margin-top: 3em;
  margin-bottom: 3em;
}

.prose :where(blockquote):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  font-weight: 500;
  font-style: italic;
  color: var(--tw-prose-quotes);
  border-inline-start-width: 0.25rem;
  border-inline-start-color: var(--tw-prose-quote-borders);
  quotes: "\201C""\201D""\2018""\2019";
  margin-top: 1.6em;
  margin-bottom: 1.6em;
  padding-inline-start: 1em;
}

.prose :where(blockquote p:first-of-type):not(:where([class~="not-prose"],[class~="not-prose"] *))::before {
  content: open-quote;
}

.prose :where(blockquote p:last-of-type):not(:where([class~="not-prose"],[class~="not-prose"] *))::after {
  content: close-quote;
}

.prose :where(h1):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-headings);
  font-weight: 800;
  font-size: 2.25em;
  margin-top: 0;
  margin-bottom: 0.8888889em;
  line-height: 1.1111111;
}

.prose :where(h1 strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  font-weight: 900;
  color: inherit;
}

.prose :where(h2):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-headings);
  font-weight: 700;
  font-size: 1.5em;
  margin-top: 2em;
  margin-bottom: 1em;
  line-height: 1.3333333;
}

.prose :where(h2 strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  font-weight: 800;
  color: inherit;
}

.prose :where(h3):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-headings);
  font-weight: 600;
  font-size: 1.25em;
  margin-top: 1.6em;
  margin-bottom: 0.6em;
  line-height: 1.6;
}

.prose :where(h3 strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  font-weight: 700;
  color: inherit;
}

.prose :where(h4):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-headings);
  font-weight: 600;
  margin-top: 1.5em;
  margin-bottom: 0.5em;
  line-height: 1.5;
}

.prose :where(h4 strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  font-weight: 700;
  color: inherit;
}

.prose :where(img):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 2em;
  margin-bottom: 2em;
}

.prose :where(picture):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  display: block;
  margin-top: 2em;
  margin-bottom: 2em;
}

.prose :where(video):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 2em;
  margin-bottom: 2em;
}

.prose :where(kbd):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  font-weight: 500;
  font-family: inherit;
  color: var(--tw-prose-kbd);
  box-shadow: 0 0 0 1px var(--tw-prose-kbd-shadows), 0 3px 0 var(--tw-prose-kbd-shadows);
  font-size: 0.875em;
  border-radius: 0.3125rem;
  padding-top: 0.1875em;
  padding-inline-end: 0.375em;
  padding-bottom: 0.1875em;
  padding-inline-start: 0.375em;
}

.prose :where(code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-code);
  font-weight: 600;
  font-size: 0.875em;
}

.prose :where(code):not(:where([class~="not-prose"],[class~="not-prose"] *))::before {
  content: "`";
}

.prose :where(code):not(:where([class~="not-prose"],[class~="not-prose"] *))::after {
  content: "`";
}

.prose :where(a code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
}

.prose :where(h1 code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
}

.prose :where(h2 code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
  font-size: 0.875em;
}

.prose :where(h3 code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
  font-size: 0.9em;
}

.prose :where(h4 code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
}

.prose :where(blockquote code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
}

.prose :where(thead th code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: inherit;
}

.prose :where(pre):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-pre-code);
  background-color: var(--tw-prose-pre-bg);
  overflow-x: auto;
  font-weight: 400;
  font-size: 0.875em;
  line-height: 1.7142857;
  margin-top: 1.7142857em;
  margin-bottom: 1.7142857em;
  border-radius: 0.375rem;
  padding-top: 0.8571429em;
  padding-inline-end: 1.1428571em;
  padding-bottom: 0.8571429em;
  padding-inline-start: 1.1428571em;
}

.prose :where(pre code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  background-color: transparent;
  border-width: 0;
  border-radius: 0;
  padding: 0;
  font-weight: inherit;
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
}

.prose :where(pre code):not(:where([class~="not-prose"],[class~="not-prose"] *))::before {
  content: none;
}

.prose :where(pre code):not(:where([class~="not-prose"],[class~="not-prose"] *))::after {
  content: none;
}

.prose :where(table):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  width: 100%;
  table-layout: auto;
  margin-top: 2em;
  margin-bottom: 2em;
  font-size: 0.875em;
  line-height: 1.7142857;
}

.prose :where(thead):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  border-bottom-width: 1px;
  border-bottom-color: var(--tw-prose-th-borders);
}

.prose :where(thead th):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-headings);
  font-weight: 600;
  vertical-align: bottom;
  padding-inline-end: 0.5714286em;
  padding-bottom: 0.5714286em;
  padding-inline-start: 0.5714286em;
}

.prose :where(tbody tr):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  border-bottom-width: 1px;
  border-bottom-color: var(--tw-prose-td-borders);
}

.prose :where(tbody tr:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  border-bottom-width: 0;
}

.prose :where(tbody td):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  vertical-align: baseline;
}

.prose :where(tfoot):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  border-top-width: 1px;
  border-top-color: var(--tw-prose-th-borders);
}

.prose :where(tfoot td):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  vertical-align: top;
}

.prose :where(th, td):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  text-align: start;
}

.prose :where(figure > *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0;
  margin-bottom: 0;
}

.prose :where(figcaption):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  color: var(--tw-prose-captions);
  font-size: 0.875em;
  line-height: 1.4285714;
  margin-top: 0.8571429em;
}

.prose {
  --tw-prose-body: #374151;
  --tw-prose-headings: #111827;
  --tw-prose-lead: #4b5563;
  --tw-prose-links: #111827;
  --tw-prose-bold: #111827;
  --tw-prose-counters: #6b7280;
  --tw-prose-bullets: #d1d5db;
  --tw-prose-hr: #e5e7eb;
  --tw-prose-quotes: #111827;
  --tw-prose-quote-borders: #e5e7eb;
  --tw-prose-captions: #6b7280;
  --tw-prose-kbd: #111827;
  --tw-prose-kbd-shadows: rgb(17 24 39 / 10%);
  --tw-prose-code: #111827;
  --tw-prose-pre-code: #e5e7eb;
  --tw-prose-pre-bg: #1f2937;
  --tw-prose-th-borders: #d1d5db;
  --tw-prose-td-borders: #e5e7eb;
  --tw-prose-invert-body: #d1d5db;
  --tw-prose-invert-headings: #fff;
  --tw-prose-invert-lead: #9ca3af;
  --tw-prose-invert-links: #fff;
  --tw-prose-invert-bold: #fff;
  --tw-prose-invert-counters: #9ca3af;
  --tw-prose-invert-bullets: #4b5563;
  --tw-prose-invert-hr: #374151;
  --tw-prose-invert-quotes: #f3f4f6;
  --tw-prose-invert-quote-borders: #374151;
  --tw-prose-invert-captions: #9ca3af;
  --tw-prose-invert-kbd: #fff;
  --tw-prose-invert-kbd-shadows: rgb(255 255 255 / 10%);
  --tw-prose-invert-code: #fff;
  --tw-prose-invert-pre-code: #d1d5db;
  --tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);
  --tw-prose-invert-th-borders: #4b5563;
  --tw-prose-invert-td-borders: #374151;
  font-size: 1rem;
  line-height: 1.75;
}

.prose :where(picture > img):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0;
  margin-bottom: 0;
}

.prose :where(li):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}

.prose :where(ol > li):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  padding-inline-start: 0.375em;
}

.prose :where(ul > li):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  padding-inline-start: 0.375em;
}

.prose :where(.prose > ul > li p):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0.75em;
  margin-bottom: 0.75em;
}

.prose :where(.prose > ul > li > p:first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 1.25em;
}

.prose :where(.prose > ul > li > p:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-bottom: 1.25em;
}

.prose :where(.prose > ol > li > p:first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 1.25em;
}

.prose :where(.prose > ol > li > p:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-bottom: 1.25em;
}

.prose :where(ul ul, ul ol, ol ul, ol ol):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0.75em;
  margin-bottom: 0.75em;
}

.prose :where(dl):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 1.25em;
  margin-bottom: 1.25em;
}

.prose :where(dd):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0.5em;
  padding-inline-start: 1.625em;
}

.prose :where(hr + *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0;
}

.prose :where(h2 + *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0;
}

.prose :where(h3 + *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0;
}

.prose :where(h4 + *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0;
}

.prose :where(thead th:first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  padding-inline-start: 0;
}

.prose :where(thead th:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  padding-inline-end: 0;
}

.prose :where(tbody td, tfoot td):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  padding-top: 0.5714286em;
  padding-inline-end: 0.5714286em;
  padding-bottom: 0.5714286em;
  padding-inline-start: 0.5714286em;
}

.prose :where(tbody td:first-child, tfoot td:first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  padding-inline-start: 0;
}

.prose :where(tbody td:last-child, tfoot td:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  padding-inline-end: 0;
}

.prose :where(figure):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 2em;
  margin-bottom: 2em;
}

.prose :where(.prose > :first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-top: 0;
}

.prose :where(.prose > :last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
  margin-bottom: 0;
}

/* Utility: screen-reader-only + focusable variant. */

.lwpt-sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

.lwpt-sr-only-focusable:focus { position: static; width: auto; height: auto; clip: auto; white-space: normal; }

/* Skip link */

.lwpt-skip-link {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  z-index: 50;
  border-radius: 0.25rem;
  background-color: var(--lwpt-color-text, #0f172a);
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  color: var(--lwpt-color-bg, #ffffff);
}

/* Container — reads --lwpt-content-width. */

.lwpt-container {
        max-width: var(--lwpt-content-width, 1200px);
        margin-left: auto; margin-right: auto;
        padding-left: 1.25rem; padding-right: 1.25rem;
    }

/* Buttons */

.lwpt-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-radius: 0.5rem;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
  font-weight: 600;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
        text-decoration: none !important;
}

.lwpt-btn--primary {
  background-color: var(--lwpt-color-primary, #4f46e5);
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.lwpt-btn--primary:hover {
  opacity: 0.95;
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.lwpt-btn--ghost {
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  color: var(--lwpt-color-text, #0f172a);
}

.lwpt-btn--ghost:hover {
  border-color: var(--lwpt-color-primary, #4f46e5);
}

.lwpt-icon-btn {
  display: inline-flex;
  height: 2.5rem;
  width: 2.5rem;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  color: var(--lwpt-color-text, #0f172a);
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.lwpt-icon-btn:hover {
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
}

/* ─── Header ────────────────────────────────────────────────────── */

/* Use the user-controlled CSS variable for background — Tailwind's
       `bg-surface` utility was hardcoding white and the sticky rule below
       was hardcoding rgba(255 255 255 / .9), so changing the bg color in
       the Customizer had no visible effect. */

.lwpt-header { background: var(--lwpt-header-bg, var(--lwpt-color-bg, #fff)); color: var(--lwpt-header-text, var(--lwpt-color-text, #0f172a)); position: relative; z-index: 40; }

.lwpt-header-sticky .lwpt-header {
        position: sticky; top: 0;
        /* Honor the user's chosen background; mix with 92% opacity so the
           backdrop blur still produces the frosted feel without losing
           color identity. */
        background: color-mix(in srgb, var(--lwpt-header-bg, var(--lwpt-color-bg, #fff)) 92%, transparent);
        backdrop-filter: saturate(1.2) blur(6px);
        -webkit-backdrop-filter: saturate(1.2) blur(6px);
    }

/* Fallback for browsers without color-mix support — still respect
       the variable, just without the translucency. */

@supports not (background: color-mix(in srgb, red, blue)) {
        .lwpt-header-sticky .lwpt-header { background: var(--lwpt-header-bg, var(--lwpt-color-bg, #fff)); }
    }

.lwpt-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.lwpt-header__brand img,
    .lwpt-header__brand .lwpt-site-title {
  max-height: 2.5rem;
  font-size: 1.25rem;
  line-height: 1.75rem;
  font-weight: 800;
  color: var(--lwpt-color-text, #0f172a);
  text-decoration-line: none;
}

.lwpt-header__brand .lwpt-site-title:hover {
  text-decoration-line: none;
}

.lwpt-header__nav {
  display: none;
  flex: 1 1 0%;
}

@media (min-width: 768px) {

  .lwpt-header__nav {
    display: block;
  }
}

.lwpt-header--default .lwpt-header__nav .lwpt-nav-wrap {
  display: flex;
  justify-content: center;
}

.lwpt-nav {
  margin: 0px;
  display: flex;
  list-style-type: none;
  align-items: center;
  gap: 1.5rem;
  padding: 0px;
}

.lwpt-nav a {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  font-weight: 500;
  color: var(--lwpt-color-text, #0f172a);
  text-decoration-line: none;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.lwpt-nav a:hover {
  color: var(--lwpt-color-primary, #4f46e5);
}

.lwpt-header__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

@media (min-width: 768px) {

  .lwpt-hamburger {
    display: none;
  }
}

.lwpt-header__search,
    .lwpt-header__drawer {
  border-top-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg, #ffffff);
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.lwpt-header--centered .lwpt-header__brand--center {
  display: flex;
  justify-content: center;
  padding-top: 1.5rem;
}

.lwpt-header--centered .lwpt-header__nav--center .lwpt-nav-wrap {
  display: flex;
  justify-content: center;
  padding-top: 0.5rem;
  padding-bottom: 1rem;
}

/* ─── Footer (comprehensive) ─────────────────────────────────────── */

/* Hardening: third-party plugins and aggressive caching/optimization
       layers occasionally strip footer markup or hide it. These !important
       rules guarantee the footer is in the document AND visible whenever
       the theme template emits it. */

.lwpt-footer {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        position: relative;
        margin-top: 4rem;
        color: var(--lwpt-footer-text, #cbd5e1);
        font-size: var(--lwpt-footer-text-size, 14px);
    }

.lwpt-footer a { color: var(--lwpt-footer-link, currentColor); transition: color .15s; }

.lwpt-footer a:hover { color: var(--lwpt-footer-link-hover, #fff); }

.lwpt-footer h1, .lwpt-footer h2, .lwpt-footer h3, .lwpt-footer h4, .lwpt-footer h5,
    .lwpt-footer .lwpt-widget-title,
    .lwpt-footer .widget-title { color: var(--lwpt-footer-heading, #fff); font-weight: 700; margin: 0 0 12px; font-size: var(--lwpt-footer-heading-size, 14px); }

.lwpt-footer__main { padding-top: var(--lwpt-footer-pad-top, 56px); padding-bottom: var(--lwpt-footer-pad-bottom, 24px); }

.lwpt-footer__inner { display: flex; flex-direction: column; gap: 40px; }

/* Background variants — only set background; foreground colors come
       from the bg-style-aware --lwpt-footer-text/heading/link variables
       emitted by lwpt_customizer_css(). User color picks always win.
       The footer template ALSO emits an inline `style=` on the wrapper
       so these class rules act as a baseline; inline styles override. */

.lwpt-footer.lwpt-footer--bg-surface  { background: var(--lwpt-color-bg-alt, #f8fafc); }

.lwpt-footer.lwpt-footer--bg-dark     { background: var(--lwpt-footer-bg, #0f172a); }

.lwpt-footer.lwpt-footer--bg-custom   { background: var(--lwpt-footer-bg, #0f172a); }

.lwpt-footer.lwpt-footer--bg-gradient { background: linear-gradient(135deg, var(--lwpt-footer-bg, #0f172a), var(--lwpt-footer-bg-2, #1e293b)); }

.lwpt-footer.lwpt-footer--bg-image    { background: var(--lwpt-footer-bg, #0f172a); position: relative; }

.lwpt-footer.lwpt-footer--bg-dark,
    .lwpt-footer.lwpt-footer--bg-custom,
    .lwpt-footer.lwpt-footer--bg-gradient,
    .lwpt-footer.lwpt-footer--bg-image    { color: var(--lwpt-footer-text, #cbd5e1); }

.lwpt-footer--bg-image::before {
        content: ""; position: absolute; inset: 0;
        background-image: var(--lwpt-footer-bg-image, none);
        background-size: cover; background-position: center;
        opacity: calc(1 - var(--lwpt-footer-bg-overlay, 0.7));
        pointer-events: none;
    }

.lwpt-footer--bg-image > * { position: relative; }

/* Container width */

.lwpt-footer--container-narrow .lwpt-container { max-width: 1080px; }

.lwpt-footer--container-wide   .lwpt-container { max-width: 1320px; }

.lwpt-footer--container-full   .lwpt-container { max-width: 100%; padding-inline: 24px; }

/* Top divider */

.lwpt-footer--divider-line     { border-top: 1px solid color-mix(in srgb, var(--lwpt-footer-text, #cbd5e1) 20%, transparent); }

.lwpt-footer--divider-gradient { position: relative; }

.lwpt-footer--divider-gradient::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: linear-gradient(90deg, var(--lwpt-color-primary, #4f46e5), var(--lwpt-color-accent, #ea580c)); }

.lwpt-footer__wave { display: block; width: 100%; height: 60px; color: var(--lwpt-footer-bg, #0f172a); margin-bottom: -1px; }

.lwpt-footer--divider-tilt { clip-path: polygon(0 24px, 100% 0, 100% 100%, 0 100%); padding-top: 24px; }

/* Brand block */

.lwpt-footer__brand { display: flex; flex-direction: column; gap: 12px; max-width: 420px; }

.lwpt-footer__brand-logo { max-width: 160px; height: auto; }

.lwpt-footer__brand-text { font-size: 14px; line-height: 1.55; opacity: .9; }

/* Newsletter block */

.lwpt-footer__newsletter { display: flex; flex-direction: column; gap: 16px; }

.lwpt-footer__newsletter--banner { padding: 28px 32px; border-radius: 14px; background: color-mix(in srgb, var(--lwpt-footer-text, #cbd5e1) 8%, transparent); border: 1px solid color-mix(in srgb, var(--lwpt-footer-text, #cbd5e1) 14%, transparent); }

.lwpt-footer__newsletter--card   { padding: 32px; border-radius: 16px; background: linear-gradient(135deg, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 14%, transparent), color-mix(in srgb, var(--lwpt-color-accent, #ea580c) 8%, transparent)); border: 1px solid color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 22%, transparent); margin-top: 24px; }

.lwpt-footer__newsletter--inline { padding: 0; }

@media (min-width: 760px) { .lwpt-footer__newsletter--banner, .lwpt-footer__newsletter--card { flex-direction: row; align-items: center; justify-content: space-between; gap: 32px; } }

.lwpt-footer__newsletter-heading { color: var(--lwpt-footer-heading, #fff); font-size: 20px; font-weight: 700; margin: 0 0 6px; }

.lwpt-footer__newsletter-sub { margin: 0; opacity: .85; font-size: 14px; }

.lwpt-footer__newsletter-form { display: flex; gap: 8px; flex: 1; max-width: 460px; }

.lwpt-footer__newsletter-form input[type="email"] {
        flex: 1; min-width: 0;
        background: rgba(255, 255, 255, .08);
        border: 1px solid color-mix(in srgb, var(--lwpt-footer-text, #cbd5e1) 25%, transparent);
        color: var(--lwpt-footer-heading, #fff);
        padding: 10px 14px; border-radius: 10px; font: inherit; outline: none;
    }

.lwpt-footer__newsletter-form input[type="email"]:focus { border-color: var(--lwpt-color-primary, #4f46e5); box-shadow: 0 0 0 3px color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 25%, transparent); }

.lwpt-footer__newsletter-form .lwpt-btn--primary { background: linear-gradient(135deg, var(--lwpt-color-primary, #4f46e5), var(--lwpt-color-accent, #ea580c)); color: #fff; padding: 10px 20px; border: 0; border-radius: 10px; font-weight: 600; cursor: pointer; transition: filter .15s, transform .15s; }

.lwpt-footer__newsletter-form .lwpt-btn--primary:hover { filter: brightness(1.06); transform: translateY(-1px); }

/* Columns */

.lwpt-footer__cols { display: grid; gap: var(--lwpt-footer-col-gap, 40px); }

.lwpt-footer__cols--1, .lwpt-footer__cols--2, .lwpt-footer__cols--3, .lwpt-footer__cols--4, .lwpt-footer__cols--5 { grid-template-columns: 1fr; }

@media (min-width: 760px) {
        .lwpt-footer__cols--2 { grid-template-columns: repeat(2, 1fr); }
        .lwpt-footer__cols--3 { grid-template-columns: repeat(3, 1fr); }
        .lwpt-footer__cols--4 { grid-template-columns: repeat(2, 1fr); }
        .lwpt-footer__cols--5 { grid-template-columns: repeat(2, 1fr); }
    }

@media (min-width: 1024px) {
        .lwpt-footer__cols--4 { grid-template-columns: repeat(4, 1fr); }
        .lwpt-footer__cols--5 { grid-template-columns: repeat(5, 1fr); }
        .lwpt-footer--colpro-wide-1 .lwpt-footer__cols--4   { grid-template-columns: 2fr 1fr 1fr 1fr; }
        .lwpt-footer--colpro-wide-1-4 .lwpt-footer__cols--4 { grid-template-columns: 2fr 1fr 1fr 2fr; }
    }

/* Column heading variants */

.lwpt-footer--head-accent-line .lwpt-widget-title,
    .lwpt-footer--head-accent-line .widget-title { padding-left: 12px; border-left: 3px solid var(--lwpt-color-primary, #4f46e5); }

.lwpt-footer--head-underline .lwpt-widget-title,
    .lwpt-footer--head-underline .widget-title { padding-bottom: 10px; border-bottom: 2px solid color-mix(in srgb, var(--lwpt-footer-text, #cbd5e1) 25%, transparent); }

.lwpt-footer--head-tracked .lwpt-widget-title,
    .lwpt-footer--head-tracked .widget-title { text-transform: uppercase; letter-spacing: .12em; font-size: calc(var(--lwpt-footer-heading-size, 14px) - 1px); }

/* Layout: split */

.lwpt-footer--split .lwpt-footer__split { display: grid; gap: 40px; }

@media (min-width: 1024px) { .lwpt-footer--split .lwpt-footer__split { grid-template-columns: minmax(260px, 1fr) 3fr; align-items: start; gap: 64px; } }

/* Layout: centered */

.lwpt-footer--centered .lwpt-footer__centered { display: flex; flex-direction: column; align-items: center; gap: 20px; text-align: center; }

.lwpt-footer__nav--center ul { justify-content: center; }

/* Bottom bar */

.lwpt-footer__bar-wrap { padding-block: 18px; border-top: 1px solid color-mix(in srgb, var(--lwpt-footer-text, #cbd5e1) 18%, transparent); }

.lwpt-footer--bar-tinted .lwpt-footer__bar-wrap { background: var(--lwpt-footer-bar-bg, #0f172a); color: var(--lwpt-footer-bar-text, #cbd5e1); border-top-color: rgba(255,255,255,.06); }

.lwpt-footer__bar { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }

.lwpt-footer__bar--split    { justify-content: space-between; }

.lwpt-footer__bar--centered { justify-content: center; flex-direction: column; text-align: center; }

.lwpt-footer__bar--stacked  { flex-direction: column; align-items: center; text-align: center; }

.lwpt-footer__bar--row-3col { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; }

.lwpt-footer__bar--row-3col .lwpt-footer__copyright { justify-self: start; }

.lwpt-footer__bar--row-3col .lwpt-social-share, .lwpt-footer__bar--row-3col .lwpt-nav { justify-self: end; }

@media (max-width: 760px) {
        .lwpt-footer__bar { flex-direction: column; text-align: center; }
        .lwpt-footer__bar--row-3col { grid-template-columns: 1fr; gap: 10px; }
        .lwpt-footer__bar--row-3col .lwpt-footer__copyright,
        .lwpt-footer__bar--row-3col .lwpt-social-share,
        .lwpt-footer__bar--row-3col .lwpt-nav { justify-self: center; }
    }

.lwpt-footer__copyright { font-size: 13.5px; margin: 0; }

.lwpt-footer__credit { opacity: .8; }

/* Sticky footer — flex push so the footer always sits at viewport bottom */

body.lwpt-footer-sticky { display: flex; flex-direction: column; min-height: 100vh; }

body.lwpt-footer-sticky .lwpt-main-wrap { flex: 1 0 auto; }

body.lwpt-footer-sticky .lwpt-footer { flex-shrink: 0; }

/* Hide-on-mobile helpers */

@media (max-width: 760px) {
        .lwpt-footer--brand-hide-mobile .lwpt-footer__brand { display: none; }
        .lwpt-footer--nl-hide-mobile    .lwpt-footer__newsletter { display: none; }
        .lwpt-footer--bar-hide-mobile   .lwpt-footer__bar-wrap { display: none; }
    }

/* Newsletter — privacy + feedback states */

.lwpt-footer__newsletter-privacy { margin: 8px 0 0; font-size: 12px; opacity: .7; }

.lwpt-footer__newsletter-feedback { margin: 10px 0 0; font-size: 13px; padding: 8px 12px; border-radius: 8px; }

.lwpt-footer__newsletter-feedback.is-success { background: rgba(16, 185, 129, .12); color: #10b981; }

.lwpt-footer__newsletter-feedback.is-error   { background: rgba(239, 68, 68, .12); color: #ef4444; }

.lwpt-footer__newsletter-spinner {
        display: none; width: 14px; height: 14px; border-radius: 50%;
        border: 2px solid rgba(255, 255, 255, .35); border-top-color: #fff;
        animation: lwpt-spin .8s linear infinite; margin-left: 4px; vertical-align: middle;
    }

.lwpt-footer__newsletter-form.is-loading .lwpt-footer__newsletter-spinner { display: inline-block; }

.lwpt-footer__newsletter-form.is-loading .lwpt-footer__newsletter-btn-label { opacity: .8; }

.lwpt-footer__newsletter-form.is-loading button { opacity: .85; cursor: progress; }

/* Brand — social row tucked under brand text */

.lwpt-footer__brand-social { margin-top: 4px; }

.lwpt-footer__brand-logo-wrap { display: inline-flex; align-items: center; }

.lwpt-footer__brand-logo-text { color: var(--lwpt-footer-heading, #fff); font-weight: 800; text-decoration: none; font-size: 20px; letter-spacing: -0.02em; }

/* Magazine layout */

.lwpt-footer--magazine .lwpt-footer__magazine { display: flex; flex-direction: column; gap: 32px; }

.lwpt-footer--magazine .lwpt-footer__magazine-row {
        display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px 28px;
        padding-bottom: 20px;
        border-bottom: 1px solid color-mix(in srgb, var(--lwpt-footer-text, #cbd5e1) 18%, transparent);
    }

/* Pre-footer CTA banner */

.lwpt-footer-pre {
        position: relative;
        padding: 56px 0;
        color: #fff;
    }

.lwpt-footer-pre__inner { display: flex; align-items: center; gap: 32px; flex-wrap: wrap; }

.lwpt-footer-pre--gradient { background: linear-gradient(135deg, var(--lwpt-color-primary, #4f46e5), var(--lwpt-color-accent, #ea580c)); }

.lwpt-footer-pre--solid    { background: var(--lwpt-color-primary, #4f46e5); }

.lwpt-footer-pre--dark     { background: #0f172a; }

.lwpt-footer-pre--outline  { background: transparent; padding: 32px 0; color: var(--lwpt-color-text, #0f172a); }

.lwpt-footer-pre--outline .lwpt-footer-pre__inner {
        background: var(--lwpt-color-bg-alt, #f8fafc);
        border: 1px solid var(--lwpt-color-border, #e2e8f0);
        border-radius: 18px; padding: 32px 36px;
    }

.lwpt-footer-pre--outline .lwpt-footer-pre__btn { background: var(--lwpt-color-primary, #4f46e5); color: #fff; }

.lwpt-footer-pre--centered .lwpt-footer-pre__inner { flex-direction: column; text-align: center; justify-content: center; }

.lwpt-footer-pre__text { flex: 1; min-width: 0; }

.lwpt-footer-pre__heading { font-size: clamp(22px, 3vw, 32px); font-weight: 800; margin: 0 0 6px; line-height: 1.2; color: inherit; }

.lwpt-footer-pre__sub { margin: 0; opacity: .92; font-size: 15px; }

.lwpt-footer-pre__btn {
        display: inline-flex; align-items: center; gap: 8px;
        background: #fff; color: #0f172a;
        padding: 12px 22px; border-radius: 10px;
        font-weight: 700; text-decoration: none;
        box-shadow: 0 1px 0 rgba(255,255,255,.3) inset, 0 8px 18px -6px rgba(0,0,0,.25);
        transition: transform .15s, filter .15s, box-shadow .2s;
        white-space: nowrap;
    }

.lwpt-footer-pre__btn:hover { transform: translateY(-1px); filter: brightness(1.04); }

.lwpt-footer-pre--gradient .lwpt-footer-pre__btn,
    .lwpt-footer-pre--solid    .lwpt-footer-pre__btn,
    .lwpt-footer-pre--dark     .lwpt-footer-pre__btn { background: #fff; color: #0f172a; }

/* Brand block tighter spacing in split layout */

.lwpt-footer--split .lwpt-footer__brand { max-width: none; }

/* Bar tinted section honors footer container width */

.lwpt-footer--container-narrow .lwpt-footer__bar-wrap .lwpt-container { max-width: 1080px; }

.lwpt-footer--container-wide   .lwpt-footer__bar-wrap .lwpt-container { max-width: 1320px; }

.lwpt-footer--container-full   .lwpt-footer__bar-wrap .lwpt-container { max-width: 100%; padding-inline: 24px; }

/* Footer social icons — strip default link styling so hover state from
       the social-share component remains intact */

.lwpt-footer .lwpt-social-share a { color: inherit; }

.lwpt-footer .lwpt-social-share a:hover { color: var(--lwpt-footer-link-hover, #fff); }

/* ─── Decorative pattern overlays ─────────────────────────────────── */

body.lwpt-footer-pattern-dots .lwpt-footer,
    body.lwpt-footer-pattern-grid .lwpt-footer,
    body.lwpt-footer-pattern-noise .lwpt-footer,
    body.lwpt-footer-pattern-rays .lwpt-footer { position: relative; isolation: isolate; }

body.lwpt-footer-pattern-dots .lwpt-footer::before,
    body.lwpt-footer-pattern-grid .lwpt-footer::before,
    body.lwpt-footer-pattern-noise .lwpt-footer::before,
    body.lwpt-footer-pattern-rays .lwpt-footer::before {
        content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
        opacity: .14; mix-blend-mode: overlay;
    }

body.lwpt-footer-pattern-dots  .lwpt-footer::before { background-image: radial-gradient(currentColor 1px, transparent 1px); background-size: 18px 18px; opacity: .12; mix-blend-mode: normal; }

body.lwpt-footer-pattern-grid  .lwpt-footer::before { background-image: linear-gradient(currentColor 1px, transparent 1px), linear-gradient(90deg, currentColor 1px, transparent 1px); background-size: 32px 32px; opacity: .07; mix-blend-mode: normal; }

body.lwpt-footer-pattern-noise .lwpt-footer::before { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'><filter id='n'><feTurbulence baseFrequency='.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .5 0'/></filter><rect width='160' height='160' filter='url(%23n)'/></svg>"); opacity: .12; mix-blend-mode: overlay; }

body.lwpt-footer-pattern-rays  .lwpt-footer::before { background: radial-gradient(ellipse 80% 60% at 50% 0%, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 30%, transparent), transparent 70%); opacity: 1; mix-blend-mode: normal; }

.lwpt-footer > * { position: relative; z-index: 1; }

/* ─── Ambient glow accents ────────────────────────────────────────── */

body.lwpt-footer-glow-top .lwpt-footer,
    body.lwpt-footer-glow-corners .lwpt-footer,
    body.lwpt-footer-glow-aurora .lwpt-footer { position: relative; isolation: isolate; overflow: hidden; }

body.lwpt-footer-glow-top .lwpt-footer::after {
        content: ""; position: absolute; inset: -20% 10% auto 10%; height: 320px; pointer-events: none; z-index: 0;
        background: radial-gradient(ellipse 80% 100% at 50% 0%, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 38%, transparent), transparent 70%);
        filter: blur(40px);
    }

body.lwpt-footer-glow-corners .lwpt-footer::after {
        content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
        background:
            radial-gradient(circle 320px at 0% 0%, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 40%, transparent), transparent 70%),
            radial-gradient(circle 320px at 100% 0%, color-mix(in srgb, var(--lwpt-color-accent, #ea580c) 35%, transparent), transparent 70%);
        filter: blur(20px);
    }

body.lwpt-footer-glow-aurora .lwpt-footer::after {
        content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
        background:
            radial-gradient(ellipse 60% 80% at 20% 30%, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 30%, transparent), transparent 70%),
            radial-gradient(ellipse 50% 70% at 80% 60%, color-mix(in srgb, var(--lwpt-color-accent, #ea580c) 28%, transparent), transparent 70%);
        animation: lwpt-aurora 14s ease-in-out infinite alternate;
        filter: blur(40px);
    }

@keyframes lwpt-aurora {
        0%   { transform: translate3d(0, 0, 0); }
        100% { transform: translate3d(20px, -10px, 0); }
    }

@media (prefers-reduced-motion: reduce) {
        body.lwpt-footer-glow-aurora .lwpt-footer::after { animation: none; }
    }

/* Back-to-top variants */

.lwpt-back-to-top {
        position: fixed; right: 24px; bottom: 24px;
        width: 44px; height: 44px;
        background: var(--lwpt-footer-btt-bg, #0f172a); color: var(--lwpt-footer-btt-color, #fff);
        border: 0; border-radius: 999px;
        display: none; align-items: center; justify-content: center;
        box-shadow: 0 4px 14px rgba(15, 23, 42, .25);
        cursor: pointer; opacity: 0; transform: translateY(8px);
        transition: opacity .2s, transform .2s, box-shadow .15s;
        z-index: 90;
    }

.lwpt-back-to-top.is-visible { display: flex; opacity: 1; transform: translateY(0); }

.lwpt-back-to-top:hover { box-shadow: 0 8px 24px rgba(15, 23, 42, .35); }

body.lwpt-btt-square .lwpt-back-to-top { border-radius: 8px; }

body.lwpt-btt-pill   .lwpt-back-to-top { width: auto; padding: 0 18px; border-radius: 999px; }

body.lwpt-btt-left   .lwpt-back-to-top { right: auto; left: 24px; }

body.lwpt-btt-center .lwpt-back-to-top { right: auto; left: 50%; transform: translateX(-50%) translateY(8px); }

body.lwpt-btt-center .lwpt-back-to-top.is-visible { transform: translateX(-50%) translateY(0); }

/* Social menu icons (ul/li list) */

.lwpt-social {
  margin: 0px;
  display: flex;
  list-style-type: none;
  align-items: center;
  gap: 0.5rem;
  padding: 0px;
}

.lwpt-social a {
  display: inline-flex;
  height: 2.25rem;
  width: 2.25rem;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg, #ffffff);
  color: var(--lwpt-color-text, #0f172a);
  text-decoration-line: none;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.lwpt-social a:hover {
  border-color: var(--lwpt-color-primary, #4f46e5);
  color: var(--lwpt-color-primary, #4f46e5);
}

/* Back to top */

.lwpt-back-to-top {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 40;
  display: none;
  height: 2.75rem;
  width: 2.75rem;
  --tw-translate-y: 0.5rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  background-color: var(--lwpt-color-text, #0f172a);
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
  opacity: 0;
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.lwpt-back-to-top.is-visible {
  display: flex;
  --tw-translate-y: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  opacity: 1;
}

/* ─── Breadcrumbs ───────────────────────────────────────────────── */

.lwpt-breadcrumbs {
  margin-bottom: 1.5rem;
}

.lwpt-breadcrumbs__list {
  margin: 0px;
  display: flex;
  list-style-type: none;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding: 0px;
  font-size: 0.875rem;
  line-height: 1.25rem; color: var(--lwpt-s-bc-color, var(--lwpt-color-muted, #64748b));
}

.lwpt-breadcrumbs__item + .lwpt-breadcrumbs__item::before { content: "/"; margin-left: 0.25rem; margin-right: 0.25rem; color: var(--lwpt-s-bc-sep, var(--lwpt-color-border, #cbd5e1)); }

.lwpt-breadcrumbs__item a {
  text-decoration-line: none; color: var(--lwpt-s-bc-link, var(--lwpt-color-muted, #64748b));
}

.lwpt-breadcrumbs__item a:hover { color: var(--lwpt-s-bc-link-hover, var(--lwpt-color-primary, #4f46e5)); }

.lwpt-breadcrumbs__item.is-current span {
  font-weight: 500; color: var(--lwpt-s-bc-current, var(--lwpt-color-text, #0f172a));
}

/* ─── Single post ──────────────────────────────────────────────── */

.lwpt-single {
  display: grid;
  gap: 2.5rem;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

@media (min-width: 768px) {

  .lwpt-single--right-sidebar {
    grid-template-columns: 1fr var(--lwpt-sidebar-width,320px);
  }

  .lwpt-single--left-sidebar {
    grid-template-columns: var(--lwpt-sidebar-width,320px) 1fr;
  }
}

.lwpt-single--left-sidebar .lwpt-sidebar { order: -1; }

.lwpt-entry {
  min-width: 0px;
}

.lwpt-entry-title {
  margin-bottom: 1rem;
}

.lwpt-entry-header {
  margin-bottom: 2rem;
}

.lwpt-entry-header__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-meta {
  margin: 0px;
  display: flex;
  list-style-type: none;
  flex-wrap: wrap;
  align-items: center;
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
  row-gap: 0.25rem;
  padding: 0px;
}

/* Link color reads the user's customizer setting first; fall through to
       muted. The .lwpt-single-scoped rule below doesn't apply when the meta
       renders inside an outside-the-container title area. */

.lwpt-meta a {
  text-decoration-line: none;
}

.lwpt-meta a:hover {
  color: var(--lwpt-color-primary, #4f46e5);
}

.lwpt-meta a { color: var(--lwpt-s-meta-link, var(--lwpt-color-muted, #64748b)); }

.lwpt-meta__item--cat a {
  display: inline-flex;
  align-items: center;
  border-radius: 9999px;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-decoration-line: none; color: var(--lwpt-s-meta-cat-text, var(--lwpt-color-primary, #4f46e5)); background: var(--lwpt-s-meta-cat-bg, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 12%, transparent));
}

.lwpt-reading-time {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.875rem;
  line-height: 1.25rem; color: var(--lwpt-s-rt-color, var(--lwpt-color-muted, #64748b));
}

.lwpt-reading-time svg { color: var(--lwpt-s-rt-icon, var(--lwpt-color-primary, #4f46e5)); }

.lwpt-featured {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}

.lwpt-featured img {
  height: auto;
  width: 100%;
  border-radius: 14px;
  -o-object-fit: cover;
     object-fit: cover;
}

.lwpt-featured__caption {
  margin-top: 0.5rem;
  text-align: center;
  font-size: 0.75rem;
  line-height: 1rem;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-featured--bleed {
  margin-left: -1rem;
  margin-right: -1rem;
  margin-top: 0px;
  margin-bottom: 0px;
}

@media (min-width: 768px) {

  .lwpt-featured--bleed {
    margin-left: 0px;
    margin-right: 0px;
  }
}

.lwpt-featured--bleed img {
  height: 40vh;
  border-radius: 0px;
  -o-object-fit: cover;
     object-fit: cover;
}

@media (min-width: 768px) {

  .lwpt-featured--bleed img {
    height: 55vh;
  }
}

/* Width is constrained by --lwpt-prose-width; horizontal alignment is
       driven by --lwpt-content-align (left | center | right). Defaults to
       `left` so existing sites are unaffected, but the new Layout tab now
       lets users pick "Center" which sets the variable to `center` and
       collapses the auto-margins on both sides. */

.lwpt-prose {
        max-width: var(--lwpt-prose-width, 760px);
        margin-inline-start: var(--lwpt-content-mis, 0);
        margin-inline-end:   var(--lwpt-content-mie, auto);
    }

.lwpt-prose h2 {
  margin-top: 2.5rem;
  margin-bottom: 1rem;
}

.lwpt-prose h3 {
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}

.lwpt-prose p {
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
}

.lwpt-prose ul, .lwpt-prose ol {
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
  padding-left: 1.5rem;
}

.lwpt-prose li {
  margin-top: 0.25rem;
  margin-bottom: 0.25rem;
}

.lwpt-prose a {
  text-decoration-line: underline;
}

.lwpt-prose blockquote {
  margin-top: 2rem;
  margin-bottom: 2rem;
  border-left-width: 4px;
  padding-left: 1.25rem;
  font-style: italic;
  color: var(--lwpt-color-muted, #64748b); border-color: color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 35%, transparent);
}

.lwpt-prose img {
  border-radius: 14px;
}

.lwpt-prose figure {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.lwpt-prose pre {
  overflow: auto;
  border-radius: 14px;
  background-color: var(--lwpt-color-text, #0f172a);
  padding: 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.lwpt-prose code {
  border-radius: 0.25rem;
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  padding-left: 0.25rem;
  padding-right: 0.25rem;
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
  font-size: 0.9em;
  color: var(--lwpt-color-text, #0f172a);
}

.lwpt-prose pre code {
  background-color: transparent;
  padding: 0px;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.lwpt-prose table {
  margin-top: 2rem;
  margin-bottom: 2rem;
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.lwpt-prose th, .lwpt-prose td {
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  text-align: left;
}

/* ─── TOC ───────────────────────────────────────────────────────── */

/* ── Table of Contents — modern editorial design ─────────────── */

.lwpt-toc {
        position: relative;
        margin: 2rem 0;
        padding: 18px 22px 16px;
        background: var(--lwpt-color-bg-alt, #f8fafc);
        border: 1px solid var(--lwpt-color-border, #e2e8f0);
        border-radius: 14px;
        overflow: hidden;
    }

/* Subtle gradient top accent — gives the card a lifted feel. */

.lwpt-toc::before {
        content: "";
        position: absolute;
        inset: 0 0 auto 0;
        height: 3px;
        background: linear-gradient(90deg,
            var(--lwpt-color-primary, #6366f1),
            var(--lwpt-color-accent, #8b5cf6) 60%,
            transparent);
        opacity: .85;
        pointer-events: none;
    }

.lwpt-toc__title {
        display: flex;
        align-items: center;
        gap: 10px;
        list-style: none;
        cursor: pointer;
        -webkit-user-select: none;
           -moz-user-select: none;
                user-select: none;
        font-size: 12px;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        color: var(--lwpt-color-heading, #0f172a);
        padding: 4px 0;
    }

.lwpt-toc__title::-webkit-details-marker { display: none; }

.lwpt-toc__title-icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 26px;
        height: 26px;
        border-radius: 8px;
        color: #fff;
        background: linear-gradient(135deg,
            var(--lwpt-color-primary, #6366f1),
            var(--lwpt-color-accent, #8b5cf6));
        flex-shrink: 0;
    }

.lwpt-toc__title-label {
        flex: 1;
        min-width: 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

.lwpt-toc__title-count {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 22px;
        height: 22px;
        padding: 0 7px;
        font-size: 11px;
        font-weight: 700;
        font-variant-numeric: tabular-nums;
        color: var(--lwpt-color-muted, #64748b);
        background: rgba(15, 23, 42, .06);
        border-radius: 999px;
        letter-spacing: 0;
        text-transform: none;
    }

.lwpt-toc__title-chevron {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 22px;
        height: 22px;
        color: var(--lwpt-color-muted, #64748b);
        transition: transform .25s cubic-bezier(.2, .9, .3, 1.2), color .2s ease;
    }

.lwpt-toc[open] .lwpt-toc__title-chevron { transform: rotate(180deg); color: var(--lwpt-color-primary, #6366f1); }

.lwpt-toc__nav {
        position: relative;
        margin-top: 14px;
        padding-left: 14px;
    }

/* Vertical rail — left guide along all items, with an animated fill that
       tracks scrollspy progress through the article. */

.lwpt-toc__rail {
        position: absolute;
        left: 0;
        top: 4px;
        bottom: 4px;
        width: 2px;
        background: var(--lwpt-color-border, #e2e8f0);
        border-radius: 2px;
        overflow: hidden;
    }

.lwpt-toc__rail-fill {
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg,
            var(--lwpt-color-primary, #6366f1),
            var(--lwpt-color-accent, #8b5cf6));
        transform: scaleY(var(--lwpt-toc-progress, 0));
        transform-origin: top;
        transition: transform .15s ease;
    }

.lwpt-toc__list {
        list-style: none;
        margin: 0;
        padding: 0;
        counter-reset: lwpttoc;
    }

.lwpt-toc__item {
        counter-increment: lwpttoc;
        margin: 0;
    }

.lwpt-toc__item a {
        position: relative;
        display: flex;
        align-items: flex-start;
        gap: 10px;
        padding: 7px 12px 7px 14px;
        margin: 1px 0;
        border-radius: 8px;
        color: var(--lwpt-color-text, #1f2937);
        font-size: 14px;
        line-height: 1.45;
        text-decoration: none;
        transition: background .15s ease, color .15s ease, transform .15s ease;
    }

.lwpt-toc__item a::before {
        content: "";
        position: absolute;
        left: -14px;
        top: 50%;
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: transparent;
        transform: translate(-2px, -50%);
        transition: background .15s ease, transform .15s ease, box-shadow .15s ease;
    }

.lwpt-toc__item a:hover {
        background: rgba(99, 102, 241, .06);
        color: var(--lwpt-color-primary, #6366f1);
        transform: translateX(2px);
    }

.lwpt-toc__item a.is-active {
        color: var(--lwpt-color-primary, #6366f1);
        font-weight: 600;
        background: linear-gradient(90deg,
            color-mix(in srgb, var(--lwpt-color-primary, #6366f1) 8%, transparent),
            transparent 80%);
    }

.lwpt-toc__item a.is-active::before {
        background: var(--lwpt-color-primary, #6366f1);
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--lwpt-color-primary, #6366f1) 18%, transparent);
        transform: translate(0, -50%);
    }

/* Numbered variant */

.lwpt-toc--numbered .lwpt-toc__item a::after {
        content: counter(lwpttoc, decimal-leading-zero);
        order: -1;
        font-size: 11px;
        font-weight: 700;
        font-variant-numeric: tabular-nums;
        color: var(--lwpt-color-muted, #94a3b8);
        margin-right: 2px;
        margin-top: 3px;
        opacity: .7;
        letter-spacing: .02em;
    }

.lwpt-toc--numbered .lwpt-toc__item a.is-active::after { color: var(--lwpt-color-primary, #6366f1); opacity: 1; }

/* Depth indentation */

.lwpt-toc__item--h3 a { padding-left: 30px; font-size: 13.5px; }

.lwpt-toc__item--h4 a { padding-left: 46px; font-size: 13px;   color: var(--lwpt-color-muted, #475569); }

.lwpt-toc__item--h3 a::before { left: 16px; }

.lwpt-toc__item--h4 a::before { left: 32px; }

/* "Back to top" footer link */

.lwpt-toc__totop {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        margin: 14px 0 2px;
        padding: 6px 12px;
        background: transparent;
        border: 1px dashed var(--lwpt-color-border, #e2e8f0);
        border-radius: 999px;
        color: var(--lwpt-color-muted, #64748b);
        font-size: 11.5px;
        font-weight: 600;
        cursor: pointer;
        transition: color .15s ease, border-color .15s ease, background .15s ease;
    }

.lwpt-toc__totop:hover,
    .lwpt-toc__totop:focus-visible {
        color: var(--lwpt-color-primary, #6366f1);
        border-color: var(--lwpt-color-primary, #6366f1);
        background: color-mix(in srgb, var(--lwpt-color-primary, #6366f1) 6%, transparent);
        outline: none;
    }

/* ─── Social share ─────────────────────────────────────────────── */

.lwpt-social-share {
  margin-top: 2rem;
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  border-top-width: 1px;
  border-bottom-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.lwpt-social-share__label {
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-social-share__list {
  margin: 0px;
  display: flex;
  list-style-type: none;
  align-items: center;
  gap: 0.5rem;
  padding: 0px;
}

.lwpt-social-share__link {
  display: inline-flex;
  height: 2.5rem;
  width: 2.5rem;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  color: var(--lwpt-color-text, #0f172a);
  text-decoration-line: none;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.lwpt-social-share__link:hover {
  border-color: var(--lwpt-color-primary, #4f46e5);
  color: var(--lwpt-color-primary, #4f46e5);
}

.lwpt-social-share--floating {
  position: fixed;
  top: 50%;
  z-index: 30;
  margin-top: 0px;
  margin-bottom: 0px;
  display: none;
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  flex-direction: column;
  border-width: 0px;
  padding-top: 0px;
  padding-bottom: 0px;
}

@media (min-width: 1024px) {

  .lwpt-social-share--floating {
    display: flex;
  }
}

.lwpt-social-share--floating-left  { left: 16px; right: auto; }

.lwpt-social-share--floating-right { right: 16px; left: auto; }

/* Backwards compat — old single-value `floating` defaults to left rail */

.lwpt-social-share--floating:not(.lwpt-social-share--floating-left):not(.lwpt-social-share--floating-right) { left: 16px; }

.lwpt-social-share--floating .lwpt-social-share__label {
  display: none;
}

.lwpt-social-share--floating .lwpt-social-share__list {
  flex-direction: column;
  gap: 0.5rem;
}

/* ─── Author box ───────────────────────────────────────────────── */

.lwpt-author-box {
  margin-top: 2.5rem;
  margin-bottom: 2.5rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.5rem;
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  padding: 1.5rem;
}

@media (min-width: 768px) {

  .lwpt-author-box {
    flex-direction: row;
  }
}

.lwpt-author-box__avatar img {
  height: 5rem;
  width: 5rem;
  border-radius: 9999px;
}

.lwpt-author-box__kicker {
  margin: 0px;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-author-box__name {
  margin-top: 0.25rem;
  margin-bottom: 0.5rem;
  font-size: 1.25rem;
  line-height: 1.75rem;
}

.lwpt-author-box__name a {
  color: var(--lwpt-color-text, #0f172a);
  text-decoration-line: none;
}

.lwpt-author-box__name a:hover {
  color: var(--lwpt-color-primary, #4f46e5);
}

.lwpt-author-box__bio {
  margin: 0px;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-author-box__link {
  margin-top: 0.5rem;
  display: inline-block;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: var(--lwpt-color-primary, #4f46e5);
}

/* ─── Post navigation ──────────────────────────────────────────── */

.lwpt-post-nav {
  margin-top: 2.5rem;
  margin-bottom: 2.5rem;
  display: grid;
  gap: 1rem;
}

@media (min-width: 768px) {

  .lwpt-post-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.lwpt-post-nav__link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  padding: 1rem;
  text-decoration-line: none;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.lwpt-post-nav__link:hover {
  border-color: var(--lwpt-color-primary, #4f46e5);
}

@media (min-width: 768px) {

  .lwpt-post-nav__link--next {
    flex-direction: row-reverse;
    text-align: right;
  }
}

.lwpt-post-nav__thumb img {
  height: 4rem;
  width: 4rem;
  border-radius: 0.25rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.lwpt-post-nav__label {
  display: block;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-post-nav__title {
  margin-top: 0.25rem;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  display: block;
  font-weight: 600;
  color: var(--lwpt-color-text, #0f172a);
}

/* ─── Related posts ────────────────────────────────────────────── */

/* Related posts — the PHP template emits `.lwpt-related__wrap--{N}` so
       these grid rules MUST match that class (not `__grid`). */

.lwpt-related {
  margin-top: 3.5rem;
  margin-bottom: 3.5rem;
}

.lwpt-related__title {
  margin-bottom: 1.5rem;
}

.lwpt-related--grid .lwpt-related__wrap {
  display: grid;
  gap: 1.5rem; grid-template-columns: 1fr;
}

@media (min-width: 768px) {
        .lwpt-related--grid .lwpt-related__wrap--2 { grid-template-columns: repeat(2, 1fr); }
        .lwpt-related--grid .lwpt-related__wrap--3 { grid-template-columns: repeat(3, 1fr); }
        .lwpt-related--grid .lwpt-related__wrap--4 { grid-template-columns: repeat(2, 1fr); }
    }

@media (min-width: 1024px) {
        .lwpt-related--grid .lwpt-related__wrap--4 { grid-template-columns: repeat(4, 1fr); }
        .lwpt-related--grid .lwpt-related__wrap--6 { grid-template-columns: repeat(6, 1fr); }
    }

.lwpt-related__card {
        background: var(--lwpt-color-card-bg, #fff);
        border: 1px solid var(--lwpt-color-border, #e2e8f0);
        border-radius: 14px;
        overflow: hidden;
        transition: transform .2s, box-shadow .2s, border-color .15s;
        display: flex; flex-direction: column;
        min-width: 0;
    }

.lwpt-related__card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px -12px rgba(15,23,42,.16); border-color: color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 25%, var(--lwpt-color-border, #e2e8f0)); }

.lwpt-related__media { display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--lwpt-color-bg-alt, #f8fafc); }

.lwpt-related__media img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; transition: transform .35s ease; }

.lwpt-related__card:hover .lwpt-related__media img { transform: scale(1.04); }

.lwpt-related__body { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 8px; flex: 1; min-width: 0; }

.lwpt-related__cat {
        align-self: flex-start;
        text-decoration: none;
        font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
        color: var(--lwpt-color-primary, #4f46e5);
        background: color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 12%, transparent);
        padding: 3px 9px; border-radius: 999px;
    }

.lwpt-related__heading { font-size: 16px; font-weight: 700; line-height: 1.35; margin: 0; }

.lwpt-related__heading a { color: var(--lwpt-color-heading, #0f172a); text-decoration: none; }

.lwpt-related__heading a:hover { color: var(--lwpt-color-primary, #4f46e5); }

.lwpt-related__excerpt { font-size: 13.5px; color: var(--lwpt-color-muted, #64748b); margin: 0; line-height: 1.55; }

.lwpt-related__meta { display: flex; gap: 10px; align-items: center; font-size: 12px; color: var(--lwpt-color-muted, #64748b); margin-top: auto; }

.lwpt-related__author { font-weight: 500; }

/* ─── Comments ─────────────────────────────────────────────────── */

.lwpt-comments {
  margin-top: 3.5rem;
  margin-bottom: 3.5rem;
}

.lwpt-comments__title {
  margin-bottom: 1.5rem;
}

.lwpt-comments__list {
  margin: 0px;
  list-style-type: none;
}

.lwpt-comments__list > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}

.lwpt-comments__list {
  padding: 0px;
}

.lwpt-comments__list li {
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  padding: 1rem;
}

.lwpt-comments__empty,
    .lwpt-comments__closed,
    .lwpt-comments__login-required {
        background: var(--lwpt-color-bg-alt, #f8fafc);
        border: 1px dashed var(--lwpt-color-border, #e2e8f0);
        border-radius: 12px;
        padding: 16px 20px;
        margin: 0 0 24px;
        color: var(--lwpt-color-muted, #64748b);
        font-size: 14px;
    }

.lwpt-comments__login-required a { color: var(--lwpt-color-primary, #4f46e5); font-weight: 600; }

/* Modern comment form — refined card with proper spacing, larger input
       affordance, and a clean primary submit button. */

.comment-respond {
        margin-top: 40px;
        background: var(--lwpt-color-card-bg, #fff);
        border: 1px solid var(--lwpt-color-border, #e2e8f0);
        border-radius: 16px;
        padding: 28px 32px;
        box-shadow: 0 1px 2px rgba(15, 23, 42, .03), 0 8px 24px -12px rgba(15, 23, 42, .06);
    }

/* WP renders the textarea BEFORE the label by default — flex-reverse the
       wrapper so labels sit above their inputs like a normal form. */

.comment-respond .comment-form-comment {
        display: flex; flex-direction: column-reverse;
    }

.comment-respond .comment-form-comment label,
    .comment-respond .comment-form-author label,
    .comment-respond .comment-form-email label,
    .comment-respond .comment-form-url label {
        order: 0;
    }

.comment-respond .comment-reply-title {
        font-size: 22px; font-weight: 800; letter-spacing: -0.02em;
        margin: 0 0 8px;
        color: var(--lwpt-color-heading, #0f172a);
    }

.comment-respond .logged-in-as,
    .comment-respond .comment-notes,
    .comment-respond .must-log-in {
        font-size: 13.5px;
        color: var(--lwpt-color-muted, #64748b);
        margin: 0 0 18px;
    }

.comment-respond .logged-in-as a { color: var(--lwpt-color-primary, #4f46e5); font-weight: 500; }

.comment-respond .comment-form-comment,
    .comment-respond .comment-form-author,
    .comment-respond .comment-form-email,
    .comment-respond .comment-form-url {
        margin: 0 0 16px;
    }

.comment-respond .comment-form-author,
    .comment-respond .comment-form-email,
    .comment-respond .comment-form-url {
        display: inline-block; width: 100%;
    }

@media (min-width: 720px) {
        .comment-respond form { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 16px; }
        .comment-respond .comment-form-comment,
        .comment-respond .comment-notes,
        .comment-respond .comment-reply-title,
        .comment-respond .logged-in-as,
        .comment-respond .form-submit,
        .comment-respond .comment-form-cookies-consent { grid-column: 1 / -1; }
    }

.comment-respond label {
        display: block;
        font-size: 13px; font-weight: 600;
        color: var(--lwpt-color-text, #0f172a);
        margin-bottom: 6px;
    }

.comment-respond input[type="text"],
    .comment-respond input[type="email"],
    .comment-respond input[type="url"],
    .comment-respond textarea {
        width: 100%;
        background: var(--lwpt-color-card-bg, #fff);
        border: 1px solid var(--lwpt-color-border, #e2e8f0);
        border-radius: 10px;
        padding: 11px 14px;
        font: inherit;
        color: var(--lwpt-color-text, #0f172a);
        transition: border-color .15s, box-shadow .15s, background-color .15s;
        outline: none;
    }

.comment-respond textarea {
        min-height: 140px; resize: vertical; line-height: 1.55;
    }

.comment-respond input:focus,
    .comment-respond textarea:focus {
        border-color: var(--lwpt-color-primary, #4f46e5);
        box-shadow: 0 0 0 4px color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 18%, transparent);
    }

.comment-respond input::-moz-placeholder, .comment-respond textarea::-moz-placeholder {
        color: var(--lwpt-color-muted, #94a3b8); opacity: 1;
    }

.comment-respond input::placeholder,
    .comment-respond textarea::placeholder {
        color: var(--lwpt-color-muted, #94a3b8); opacity: 1;
    }

.comment-respond .comment-form-cookies-consent {
        display: flex; align-items: center; gap: 8px;
        font-size: 13px; color: var(--lwpt-color-muted, #64748b);
        margin: 6px 0 4px;
    }

.comment-respond .comment-form-cookies-consent input { width: 16px; height: 16px; accent-color: var(--lwpt-color-primary, #4f46e5); }

.comment-respond .comment-form-cookies-consent label { display: inline; margin: 0; font-weight: 400; }

.comment-respond .form-submit { margin: 6px 0 0; }

.comment-respond input[type="submit"],
    .comment-respond .submit,
    .comment-respond .lwpt-btn--primary {
        background: linear-gradient(135deg, var(--lwpt-color-primary, #4f46e5), var(--lwpt-color-primary-2, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5), #ea580c 35%)));
        color: #fff;
        border: 0;
        border-radius: 10px;
        padding: 12px 24px;
        font: inherit; font-weight: 600;
        cursor: pointer;
        transition: transform .15s, filter .15s, box-shadow .2s;
        box-shadow: 0 1px 0 rgba(255,255,255,.2) inset, 0 8px 18px -6px color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 60%, transparent);
    }

.comment-respond input[type="submit"]:hover,
    .comment-respond .submit:hover,
    .comment-respond .lwpt-btn--primary:hover { transform: translateY(-1px); filter: brightness(1.05); }

.comment-list .comment-author { display: flex; align-items: center; gap: 10px; font-weight: 600; }

.comment-list .comment-author img.avatar { border-radius: 999px; }

.comment-list .comment-meta { font-size: 12px; color: var(--lwpt-color-muted, #64748b); margin-bottom: 6px; }

.comment-list .comment-meta a { color: inherit; text-decoration: none; }

.comment-list .comment-content { margin-top: 6px; line-height: 1.6; }

.comment-list .reply { margin-top: 8px; }

.comment-list .reply a { font-size: 13px; font-weight: 600; color: var(--lwpt-color-primary, #4f46e5); text-decoration: none; }

/* ─── Archive loop ─────────────────────────────────────────────── */

.lwpt-archive {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.lwpt-archive-header {
  margin-bottom: 2.5rem;
  text-align: center;
}

.lwpt-archive-title {
  margin-bottom: 0.5rem;
}

.lwpt-archive-desc {
  margin-left: auto;
  margin-right: auto;
  max-width: var(--lwpt-prose-width, 760px);
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-archive-grid {
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 768px) {

  .lwpt-archive-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lwpt-archive-grid--3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {

  .lwpt-archive-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 768px) {

  .lwpt-archive-grid--4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {

  .lwpt-archive-grid--4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.lwpt-archive-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.lwpt-card {
  overflow: hidden;
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg, #ffffff);
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.lwpt-card:hover {
  --tw-translate-y: -0.25rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.lwpt-card--list {
  display: grid;
  align-items: stretch;
}

@media (min-width: 768px) {

  .lwpt-card--list {
    grid-template-columns: 280px 1fr;
  }
}

.lwpt-card__media {
  position: relative;
  display: block;
  overflow: hidden;
}

.lwpt-card__media img {
  height: 13rem;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 500ms;
}

@media (min-width: 768px) {

  .lwpt-card__media img {
    height: 100%;
  }
}

.lwpt-card:hover .lwpt-card__media img {
  --tw-scale-x: 1.05;
  --tw-scale-y: 1.05;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.lwpt-card__cat {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  border-radius: 0.25rem;
  background-color: var(--lwpt-color-primary, #4f46e5);
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.lwpt-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1.25rem;
}

@media (min-width: 768px) {

  .lwpt-card__body {
    padding: 1.5rem;
  }
}

.lwpt-card__title {
  margin-bottom: 0.25rem;
  font-size: 1.25rem;
  line-height: 1.75rem;
  font-weight: 700;
}

.lwpt-card__title a {
  color: var(--lwpt-color-text, #0f172a);
  text-decoration-line: none;
}

.lwpt-card__title a:hover {
  color: var(--lwpt-color-primary, #4f46e5);
}

.lwpt-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  line-height: 1rem;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-card__excerpt {
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-card__cta {
  margin-top: 0.5rem;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-weight: 600;
  color: var(--lwpt-color-primary, #4f46e5);
  text-decoration-line: none;
}

/* ─── Pagination ───────────────────────────────────────────────── */

.lwpt-pagination {
  margin-top: 3rem;
  display: flex;
  justify-content: center;
}

.lwpt-pagination .page-numbers {
  margin-left: 0.25rem;
  margin-right: 0.25rem;
  display: inline-flex;
  height: 2.5rem;
  min-width: 2.5rem;
  align-items: center;
  justify-content: center;
  border-radius: 0.25rem;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  color: var(--lwpt-color-text, #0f172a);
  text-decoration-line: none;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.lwpt-pagination .page-numbers:hover {
  border-color: var(--lwpt-color-primary, #4f46e5);
  color: var(--lwpt-color-primary, #4f46e5);
}

.lwpt-pagination .page-numbers.current {
  border-color: var(--lwpt-color-primary, #4f46e5);
  background-color: var(--lwpt-color-primary, #4f46e5);
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.lwpt-pagination .page-numbers.dots {
  border-width: 0px;
}

/* ─── Sidebar ──────────────────────────────────────────────────── */

.lwpt-sidebar {
  min-width: 0px;
}

@media (min-width: 768px) {

  .lwpt-sidebar--sticky {
    position: sticky;
    top: 6rem;
  }
}

.lwpt-widget {
  margin-bottom: 2rem;
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  padding: 1.25rem;
}

.lwpt-widget-title {
  margin-bottom: 0.75rem;
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: 700;
  color: var(--lwpt-color-text, #0f172a);
}

/* ─── 404 ──────────────────────────────────────────────────────── */

.lwpt-404 {
  padding-top: 6rem;
  padding-bottom: 6rem;
  text-align: center;
}

.lwpt-404__code {
  margin: 0px;
  font-size: 4.5rem;
  line-height: 1;
  font-weight: 900;
  color: var(--lwpt-color-primary, #4f46e5);
}

@media (min-width: 768px) {

  .lwpt-404__code {
    font-size: 8rem;
    line-height: 1;
  }
}

.lwpt-404__code { line-height: 1; }

.lwpt-404__title {
  margin-top: 1rem;
}

.lwpt-404__message {
  margin-top: 0.5rem;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-404__actions {
  margin-top: 1.5rem;
}

.lwpt-404__search {
  margin-left: auto;
  margin-right: auto;
  margin-top: 2.5rem;
  max-width: 28rem;
}

/* ─── No results ───────────────────────────────────────────────── */

.lwpt-no-results {
  padding-top: 5rem;
  padding-bottom: 5rem;
  text-align: center;
}

/* ─── Page (static) ────────────────────────────────────────────── */

.lwpt-page {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.lwpt-page .lwpt-entry-content { max-width: var(--lwpt-prose-width, 760px); margin-inline: auto; }

/* ─── Global radius tokens ─────────────────────────────────────── */

.lwpt-radius-none   { --lwpt-r: 0px; }

.lwpt-radius-small  { --lwpt-r: 4px; }

.lwpt-radius-medium { --lwpt-r: 10px; }

.lwpt-radius-large  { --lwpt-r: 18px; }

/* ─── Single post container-layout variants ───────────────────────── */

.lwpt-clay-full-width    { max-width: none !important; padding-left: 0 !important; padding-right: 0 !important; }

.lwpt-clay-full-width    > * { max-width: var(--lwpt-content-width, 1200px); margin-inline: auto; padding-inline: 1.25rem; }

.lwpt-clay-content-boxed { max-width: var(--lwpt-content-width, 1200px); }

.lwpt-clay-boxed {
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg, #ffffff);
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); padding: clamp(1.25rem, 3vw, 2.5rem); margin-block: 1.5rem;
}

.lwpt-clay-padded        { padding-block: 2.5rem; }

/* Container style (default/unboxed/boxed) applied to the article */

.lwpt-csty-boxed .lwpt-entry {
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg, #ffffff);
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); padding: clamp(1.25rem, 3vw, 2.5rem);
}

.lwpt-csty-unboxed .lwpt-entry { background: transparent; border: 0; box-shadow: none; padding: 0; }

/* Sidebar variants */

.lwpt-sbar-no-sidebar  { grid-template-columns: 1fr !important; }

.lwpt-sbar-no-sidebar .lwpt-sidebar { display: none; }

.lwpt-sbar-stretched   { max-width: none !important; }

.lwpt-sbar-stretched .lwpt-entry { max-width: var(--lwpt-content-width, 1200px); margin-inline: auto; padding-inline: 1.25rem; }

.lwpt-sbar-stretched .lwpt-sidebar { display: none; }

/* Sidebar style */

.lwpt-sbs-boxed   .lwpt-widget {
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  padding: 1.25rem;
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.lwpt-sbs-unboxed .lwpt-widget { background: transparent; border: 0; padding: 0; box-shadow: none; }

/* ─── Title area styles ───────────────────────────────────────────── */

.lwpt-title-area {
  margin-bottom: 2rem;
}

.lwpt-title-area__meta {
  margin-top: 0.75rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: var(--lwpt-color-muted, #64748b);
}

.lwpt-title-area__meta--align-left   { justify-content: flex-start; text-align: left;   }

.lwpt-title-area__meta--align-center { justify-content: center;     text-align: center; }

.lwpt-title-area__meta--align-right  { justify-content: flex-end;   text-align: right;  }

.lwpt-ttla-center .lwpt-title-area  { text-align: center; }

.lwpt-ttla-center .lwpt-title-area__meta { justify-content: center; }

.lwpt-ttla-right .lwpt-title-area   { text-align: right; }

.lwpt-ttla-right .lwpt-title-area__meta  { justify-content: flex-end; }

.lwpt-title-area--centered {
  text-align: center;
}

.lwpt-title-area--centered .lwpt-entry-title::after {
        content: ''; display: block; width: 54px; height: 3px; margin: 16px auto 0;
        background: var(--lwpt-color-primary, #4f46e5); border-radius: 2px;
    }

.lwpt-title-area--banner {
  margin-left: -1rem;
  margin-right: -1rem;
  border-top-width: 1px;
  border-bottom-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  text-align: center;
}

@media (min-width: 768px) {

  .lwpt-title-area--banner {
    margin-left: -0px;
    margin-right: -0px;
  }
}

.lwpt-title-area--banner {
        margin-bottom: 2.5rem;
    }

.lwpt-title-area--overlay {
  display: none; /* title shown inside featured-image overlay */
}

/* ─── Featured image: aspect-ratio, rounded, shadow, behind-title ── */

.lwpt-featured--rounded img { border-radius: 14px; }

.lwpt-featured--shadow  img { box-shadow: 0 10px 30px rgba(0,0,0,0.12); }

.lwpt-featured--ratio-16-9 img { aspect-ratio: 16/9; -o-object-fit: cover; object-fit: cover; width: 100%; height: auto; }

.lwpt-featured--ratio-4-3  img { aspect-ratio: 4/3;  -o-object-fit: cover;  object-fit: cover; width: 100%; height: auto; }

.lwpt-featured--ratio-3-2  img { aspect-ratio: 3/2;  -o-object-fit: cover;  object-fit: cover; width: 100%; height: auto; }

.lwpt-featured--ratio-1-1  img { aspect-ratio: 1/1;  -o-object-fit: cover;  object-fit: cover; width: 100%; height: auto; }

.lwpt-featured--ratio-21-9 img { aspect-ratio: 21/9; -o-object-fit: cover; object-fit: cover; width: 100%; height: auto; }

.lwpt-featured--behind-title { position: relative; }

.lwpt-featured--behind-title img { filter: brightness(0.55); aspect-ratio: 21/9; -o-object-fit: cover; object-fit: cover; width: 100%; }

.lwpt-featured__overlay {
  position: absolute;
  inset: 0px;
  display: flex;
  align-items: flex-end;
  padding-bottom: 2.5rem;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.lwpt-featured__overlay-inner {
  width: 100%;
}

.lwpt-entry-title--on-image {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1)); text-shadow: 0 1px 20px rgba(0,0,0,0.35);
}

.lwpt-featured--behind-title + .lwpt-container .lwpt-title-area { display: none; }

/* title already in overlay */

/* ─── Breadcrumbs separator via CSS var ───────────────────────────── */

.lwpt-breadcrumbs .lwpt-breadcrumbs__item + .lwpt-breadcrumbs__item::before {
        content: var(--lwpt-bc-sep, '/');
        margin-left: 0.25rem;
        margin-right: 0.25rem;
        color: var(--lwpt-color-border, #e2e8f0);
    }

.lwpt-breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center; list-style: none; padding: 0; margin: 0;
}

.lwpt-breadcrumbs--align-left   .lwpt-breadcrumbs__list { justify-content: flex-start; }

.lwpt-breadcrumbs--align-center .lwpt-breadcrumbs__list { justify-content: center; }

.lwpt-breadcrumbs--align-right  .lwpt-breadcrumbs__list { justify-content: flex-end; }

.lwpt-breadcrumbs--align-center { text-align: center; }

.lwpt-breadcrumbs--align-right  { text-align: right; }

/* ─── Post meta separators ────────────────────────────────────────── */

.lwpt-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.lwpt-meta .lwpt-meta__sep {
  margin-left: 0.25rem;
  margin-right: 0.25rem; color: var(--lwpt-s-meta-sep, var(--lwpt-color-border, #cbd5e1));
}

.lwpt-meta .lwpt-meta__sep--space { width: 8px; }

.lwpt-meta__avatar { width: 24px; height: 24px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }

.lwpt-meta__cat {
  display: inline-flex;
  align-items: center;
  border-radius: 9999px;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-decoration-line: none; color: var(--lwpt-s-meta-cat-text, var(--lwpt-color-primary, #4f46e5)); background: var(--lwpt-s-meta-cat-bg, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 12%, transparent));
}

/* ─── Social share styles & sizes ─────────────────────────────────── */

.lwpt-social-share--style-filled  .lwpt-social-share__link {
  border-color: transparent;
  background-color: var(--lwpt-color-text, #0f172a);
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.lwpt-social-share--style-filled  .lwpt-social-share__link:hover {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
  opacity: 0.8;
}

.lwpt-social-share--style-minimal .lwpt-social-share__link { border: 0; background: transparent; }

.lwpt-social-share--style-minimal .lwpt-social-share__link:hover { color: var(--lwpt-color-primary, #4f46e5); }

.lwpt-social-share--style-brand   .lwpt-social-share__link--twitter  { background: #1da1f2; color: #fff; border-color: #1da1f2; }

.lwpt-social-share--style-brand   .lwpt-social-share__link--facebook { background: #1877f2; color: #fff; border-color: #1877f2; }

.lwpt-social-share--style-brand   .lwpt-social-share__link--linkedin { background: #0a66c2; color: #fff; border-color: #0a66c2; }

.lwpt-social-share--style-brand   .lwpt-social-share__link--reddit   { background: #ff4500; color: #fff; border-color: #ff4500; }

.lwpt-social-share--style-brand   .lwpt-social-share__link--whatsapp { background: #25d366; color: #fff; border-color: #25d366; }

.lwpt-social-share--style-brand   .lwpt-social-share__link--email,
    .lwpt-social-share--style-brand   .lwpt-social-share__link--copy     { background: #0f172a; color: #fff; border-color: #0f172a; }

.lwpt-social-share--size-small  .lwpt-social-share__link {
  height: 2rem;
  width: 2rem;
}

.lwpt-social-share--size-small  .lwpt-social-share__link svg { width: 14px; height: 14px; }

.lwpt-social-share--size-large  .lwpt-social-share__link {
  height: 3rem;
  width: 3rem;
}

.lwpt-social-share--size-large  .lwpt-social-share__link svg { width: 22px; height: 22px; }

/* ─── Author-box style variants ───────────────────────────────────── */

.lwpt-author-box--avatar-round    .lwpt-author-box__avatar img { border-radius: 50%; }

.lwpt-author-box--avatar-rounded  .lwpt-author-box__avatar img { border-radius: 10px; }

.lwpt-author-box--avatar-square   .lwpt-author-box__avatar img { border-radius: 0; }

.lwpt-author-box--minimal {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  border-width: 0px;
  background-color: transparent;
  padding: 1rem;
}

.lwpt-author-box--minimal .lwpt-author-box__avatar img { width: 40px; height: 40px; }

.lwpt-author-box--minimal .lwpt-author-box__kicker { display: none; }

.lwpt-author-box--minimal .lwpt-author-box__name {
  margin: 0px;
  font-size: 1rem;
  line-height: 1.5rem;
}

.lwpt-author-box--minimal .lwpt-author-box__bio    { display: none; }

.lwpt-author-box--centered {
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.lwpt-author-box__count {
  margin-left: 0.5rem;
  vertical-align: middle;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 400;
  color: var(--lwpt-color-muted, #64748b);
}

/* ─── Post-nav styles ─────────────────────────────────────────────── */

.lwpt-post-nav--simple .lwpt-post-nav__link {
  border-width: 0px;
  background-color: transparent;
  padding: 0px;
}

.lwpt-post-nav--simple .lwpt-post-nav__link:hover {
  text-decoration-line: none;
}

.lwpt-post-nav--simple .lwpt-post-nav__thumb { display: none; }

.lwpt-post-nav--hero   .lwpt-post-nav__link {
  position: relative;
  min-height: 180px;
  align-items: flex-end;
  overflow: hidden;
  padding: 1.5rem;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.lwpt-post-nav--hero   .lwpt-post-nav__thumb {
  position: absolute;
  inset: 0px;
  margin: 0px;
}

.lwpt-post-nav--hero   .lwpt-post-nav__thumb img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; filter: brightness(0.5); }

.lwpt-post-nav--hero   .lwpt-post-nav__text {
  position: relative;
  z-index: 10;
}

.lwpt-post-nav--hero   .lwpt-post-nav__title {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.lwpt-post-nav--hero   .lwpt-post-nav__label {
  color: rgb(255 255 255 / 0.8);
}

/* ─── Related posts layouts ───────────────────────────────────────── */

.lwpt-related--list .lwpt-related__wrap { display: flex; flex-direction: column; gap: 1.25rem; }

.lwpt-related--list .lwpt-related__card { display: grid; grid-template-columns: 140px 1fr; gap: 1rem; }

.lwpt-related--list .lwpt-related__media img { height: 100%; }

.lwpt-related--compact .lwpt-related__wrap {
  display: grid;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  row-gap: 0.75rem;
}

@media (min-width: 768px) {

  .lwpt-related--compact .lwpt-related__wrap {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.lwpt-related--compact .lwpt-related__card { background: transparent; border: 0; padding: 0; display: flex; align-items: center; gap: 10px; }

.lwpt-related--compact .lwpt-related__media,
    .lwpt-related--compact .lwpt-related__body .lwpt-related__excerpt,
    .lwpt-related--compact .lwpt-related__body .lwpt-related__cat { display: none; }

.lwpt-related--compact .lwpt-related__heading {
  margin: 0px;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.lwpt-related--carousel .lwpt-related__wrap { display: flex; gap: 1rem; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; padding-bottom: 0.5rem; }

.lwpt-related--carousel .lwpt-related__card { flex: 0 0 300px; scroll-snap-align: start; }

.lwpt-related__cat {
  margin-bottom: 0.5rem;
  display: inline-block;
  border-radius: 9999px;
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--lwpt-color-primary, #4f46e5);
  text-decoration-line: none;
}

.lwpt-related__excerpt {
  margin-top: 0.25rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: var(--lwpt-color-muted, #64748b);
}

/* ─── Archive wrapper / container layouts ─────────────────────────── */

.lwpt-acont-full-width    { max-width: none; padding-inline: 0; }

.lwpt-acont-full-width    .lwpt-archive-header,
    .lwpt-acont-full-width    .lwpt-archive__body   { max-width: var(--lwpt-content-width, 1200px); margin-inline: auto; padding-inline: 1.25rem; }

.lwpt-acont-content-boxed .lwpt-archive__content { background: var(--lwpt-color-bg); border: 1px solid var(--lwpt-color-border); border-radius: 14px; padding: clamp(1.25rem, 2.5vw, 2rem); }

.lwpt-archive__body {
  display: grid;
  gap: 2.5rem;
}

.lwpt-asbar-right-sidebar .lwpt-archive__body { grid-template-columns: 1fr var(--lwpt-sidebar-width, 320px); }

.lwpt-asbar-left-sidebar  .lwpt-archive__body { grid-template-columns: var(--lwpt-sidebar-width, 320px) 1fr; }

.lwpt-asbar-left-sidebar  .lwpt-sidebar { order: -1; }

@media (max-width: 960px) {
        .lwpt-asbar-right-sidebar .lwpt-archive__body,
        .lwpt-asbar-left-sidebar  .lwpt-archive__body { grid-template-columns: 1fr; }
    }

/* ─── Archive title styles ───────────────────────────────────────── */

.lwpt-archive-header--align-left   { text-align: left;   }

.lwpt-archive-header--align-center { text-align: center; }

.lwpt-archive-header--align-right  { text-align: right;  }

.lwpt-archive-header--banner {
  border-radius: 14px;
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
  --tw-gradient-from: var(--lwpt-color-bg-alt, #f8fafc) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
  --tw-gradient-to: var(--lwpt-color-bg, #ffffff) var(--tw-gradient-to-position);
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
        margin-bottom: 2.5rem;
}

.lwpt-archive-header--centered .lwpt-archive-title::after {
        content: ''; display: block; width: 54px; height: 3px; margin: 16px auto 0;
        background: var(--lwpt-color-primary, #4f46e5); border-radius: 2px;
    }

.lwpt-archive-header--minimal {
  border-top-width: 2px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  padding-top: 1rem;
  text-align: left;
}

.lwpt-archive-header--minimal .lwpt-archive-title {
  font-size: 1.5rem;
  line-height: 2rem;
}

.lwpt-archive-kicker {
  margin-bottom: 0.25rem;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--lwpt-color-primary, #4f46e5);
}

.lwpt-archive-count {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: var(--lwpt-color-muted, #64748b);
}

/* ─── Archive card variants ───────────────────────────────────────── */

.lwpt-acard-overlay .lwpt-card { position: relative; color: #fff; border: 0; overflow: hidden; }

.lwpt-acard-overlay .lwpt-card__media { display: block; aspect-ratio: 4/3; }

.lwpt-acard-overlay .lwpt-card__media img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; filter: brightness(0.55); transition: transform 0.4s, filter 0.4s; }

.lwpt-acard-overlay .lwpt-card:hover .lwpt-card__media img { filter: brightness(0.45); transform: scale(1.04); }

.lwpt-acard-overlay .lwpt-card__body { position: absolute; inset: auto 0 0 0; padding: 1.5rem; background: linear-gradient(180deg, transparent, rgba(0,0,0,0.75)); }

.lwpt-acard-overlay .lwpt-card__title a { color: #fff; }

.lwpt-acard-overlay .lwpt-card__meta,
    .lwpt-acard-overlay .lwpt-card__excerpt { color: rgba(255,255,255,0.85); }

.lwpt-acard-minimal .lwpt-card        { background: transparent; border: 0; box-shadow: none; transform: none !important; }

.lwpt-acard-minimal .lwpt-card:hover  { background: transparent; box-shadow: none; }

.lwpt-acard-minimal .lwpt-card__body  { padding: 1.25rem 0; border-top: 1px solid var(--lwpt-color-border); }

.lwpt-acard-horizontal .lwpt-card--grid,
    .lwpt-acard-horizontal .lwpt-card--list { grid-template-columns: 280px 1fr; display: grid; }

.lwpt-acard-elevated .lwpt-card { box-shadow: 0 4px 12px rgba(0,0,0,0.06), 0 12px 32px rgba(0,0,0,0.08); }

.lwpt-acard-elevated .lwpt-card:hover { box-shadow: 0 6px 18px rgba(0,0,0,0.1), 0 20px 48px rgba(0,0,0,0.14); }

.lwpt-acard-flat .lwpt-card     { border: 0; box-shadow: none; transform: none !important; }

.lwpt-acard-flat .lwpt-card:hover { box-shadow: none; }

/* Image-hover effects */

.lwpt-aimg-zoom  .lwpt-card__media img,
    .lwpt-aimg-tint  .lwpt-card__media img,
    .lwpt-aimg-fade  .lwpt-card__media img,
    .lwpt-aimg-shift .lwpt-card__media img { transition: transform 0.5s, filter 0.5s, opacity 0.4s; }

.lwpt-aimg-zoom  .lwpt-card:hover .lwpt-card__media img { transform: scale(1.07); }

.lwpt-aimg-tint  .lwpt-card:hover .lwpt-card__media img { filter: saturate(1.3) contrast(1.1); }

.lwpt-aimg-fade  .lwpt-card:hover .lwpt-card__media img { opacity: 0.8; }

.lwpt-aimg-shift .lwpt-card:hover .lwpt-card__media img { transform: translateY(-6px); }

.lwpt-aimg-none  .lwpt-card:hover .lwpt-card__media img { transform: none; filter: none; }

/* Card title tag + avatar */

.lwpt-card__avatar { width: 20px; height: 20px; border-radius: 50%; margin-right: 4px; vertical-align: middle; }

/* Magazine layout */

.lwpt-archive-magazine__feature .lwpt-card { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }

.lwpt-archive-magazine__feature .lwpt-card__media img { height: 100%; min-height: 360px; -o-object-fit: cover; object-fit: cover; }

.lwpt-archive-magazine__feature .lwpt-card__title {
  font-size: 1.875rem;
  line-height: 2.25rem;
}

@media (max-width: 768px) {
        .lwpt-archive-magazine__feature .lwpt-card { grid-template-columns: 1fr; }
    }

.lwpt-archive-magazine__grid { margin-top: 2rem; }

/* ─── Pagination — alignment, size, shape, color, active style ───── */

.lwpt-pagination--align-left   { justify-content: flex-start; }

.lwpt-pagination--align-right  { justify-content: flex-end;   }

.lwpt-pagination .page-numbers {
        background: var(--lwpt-pag-bg, transparent);
        color:      var(--lwpt-pag-text, var(--lwpt-color-text, #0f172a));
        border-color: var(--lwpt-pag-border, var(--lwpt-color-border, #e2e8f0));
        margin: 0 calc(var(--lwpt-pag-gap, 8px) / 2);
        transition: background .15s ease, color .15s ease, border-color .15s ease, transform .15s ease, box-shadow .15s ease;
    }

.lwpt-pagination .page-numbers:hover {
        background: var(--lwpt-pag-hover-bg, var(--lwpt-color-bg-alt, #f8fafc));
        border-color: var(--lwpt-pag-active-bg, var(--lwpt-color-primary, #6366f1));
        color: var(--lwpt-pag-active-bg, var(--lwpt-color-primary, #6366f1));
    }

/* Size */

.lwpt-pagination--size-small  .page-numbers { min-width: 32px; height: 32px; font-size: 12px; }

.lwpt-pagination--size-large  .page-numbers { min-width: 48px; height: 48px; font-size: 15px; }

/* Shape */

.lwpt-pagination--shape-rounded .page-numbers { border-radius: 8px; }

.lwpt-pagination--shape-pill    .page-numbers { border-radius: 999px; }

.lwpt-pagination--shape-square  .page-numbers { border-radius: 0; }

/* Active button — solid (default), outline, gradient, underline */

.lwpt-pagination--active-solid .page-numbers.current {
        background:   var(--lwpt-pag-active-bg,   var(--lwpt-color-primary, #6366f1));
        color:        var(--lwpt-pag-active-text, #ffffff);
        border-color: var(--lwpt-pag-active-bg,   var(--lwpt-color-primary, #6366f1));
    }

.lwpt-pagination--active-outline .page-numbers.current {
        background: transparent;
        color:        var(--lwpt-pag-active-bg, var(--lwpt-color-primary, #6366f1));
        border-color: var(--lwpt-pag-active-bg, var(--lwpt-color-primary, #6366f1));
        border-width: 2px;
        font-weight: 700;
    }

.lwpt-pagination--active-gradient .page-numbers.current {
        background: linear-gradient(135deg,
            var(--lwpt-pag-active-bg, #6366f1),
            var(--lwpt-color-primary-2, #8b5cf6));
        color:        var(--lwpt-pag-active-text, #ffffff);
        border-color: transparent;
        box-shadow: 0 4px 14px -4px var(--lwpt-pag-active-bg, rgba(99, 102, 241, .5));
    }

.lwpt-pagination--active-underline .page-numbers.current {
        background: transparent;
        color:        var(--lwpt-pag-active-bg, var(--lwpt-color-primary, #6366f1));
        border-color: transparent;
        border-bottom: 2px solid var(--lwpt-pag-active-bg, var(--lwpt-color-primary, #6366f1));
        border-radius: 0;
        font-weight: 700;
    }

/* "Page X of Y" indicator */

.lwpt-pagination__total {
        margin-left: 16px;
        font-size: 13px;
        color: var(--lwpt-color-muted, #64748b);
        align-self: center;
    }

/* Load-more button — picks up theme-primary by default. */

.lwpt-loadmore {
  margin-top: 3rem;
  display: flex;
  justify-content: center;
}

.lwpt-loadmore a {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 12px 28px;
        border-radius: 999px;
        background: var(--lwpt-pag-active-bg, var(--lwpt-color-primary, #6366f1));
        color: var(--lwpt-pag-active-text, #ffffff);
        font-weight: 700;
        text-decoration: none;
        box-shadow: 0 4px 14px -4px var(--lwpt-pag-active-bg, rgba(99, 102, 241, .4));
        transition: transform .15s ease, box-shadow .15s ease;
    }

.lwpt-loadmore a:hover {
        transform: translateY(-1px);
        box-shadow: 0 8px 20px -4px var(--lwpt-pag-active-bg, rgba(99, 102, 241, .55));
    }

.lwpt-loadmore__end {
  margin-top: 3rem;
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: var(--lwpt-color-muted, #64748b);
}

/* ─── TOC floating rail ───────────────────────────────────────────── */

.lwpt-toc--floating {
  position: fixed;
  right: 1.5rem;
  top: 8rem;
  z-index: 30;
  display: none;
  max-height: 70vh;
  width: 16rem;
  overflow: auto;
}

@media (min-width: 1280px) {

  .lwpt-toc--floating {
    display: block;
  }
}

/* ─── Content options (drop cap, image shadow, link style) ────────── */

.lwpt-single [class*="single_dropcap"],
    .lwpt-prose.lwpt-dropcap > p:first-of-type::first-letter {
        float: left; font-family: var(--lwpt-font-heading, Inter); font-size: 4.5em; line-height: 0.85;
        padding: 0.2em 0.12em 0 0; font-weight: 900; color: var(--lwpt-color-primary, #4f46e5);
    }

/* ─── Announcement bar ────────────────────────────────────────────── */

.lwpt-announce {
        background: var(--lwpt-announce-bg, #0f172a);
        color: var(--lwpt-announce-color, #fff);
        padding: 10px 0; font-size: 13.5px; text-align: center;
        transition: opacity 0.25s, height 0.25s; position: relative; z-index: 50;
    }

.lwpt-announce.is-dismissed { opacity: 0; height: 0; padding: 0; overflow: hidden; }

.lwpt-announce__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}

.lwpt-announce__text  { margin: 0; }

.lwpt-announce__text a { color: inherit; text-decoration: underline; font-weight: 600; }

.lwpt-announce__close {
  display: inline-flex;
  height: 2rem;
  width: 2rem;
  align-items: center;
  justify-content: center;
  border-radius: 9999px; background: rgba(255,255,255,0.1); color: inherit; border: 0; cursor: pointer;
}

.lwpt-announce__close:hover { background: rgba(255,255,255,0.18); }

/* ─── Header global (uses CSS vars) ──────────────────────────────── */

.lwpt-header {
        background: var(--lwpt-header-bg, #fff);
        color: var(--lwpt-header-text, #0f172a);
        position: relative; z-index: 40;
        padding-top: var(--lwpt-header-pad-y, 0px);
        padding-bottom: var(--lwpt-header-pad-y, 0px);
        transition: box-shadow 0.25s, background-color 0.25s, transform 0.25s;
    }

.lwpt-header-border .lwpt-header { border-bottom: 1px solid var(--lwpt-header-border-color, #e2e8f0); }

.lwpt-header.is-hidden { transform: translateY(-100%); }

.lwpt-header--container-narrow .lwpt-header__inner { max-width: 1080px; }

.lwpt-header--container-wide   .lwpt-header__inner { max-width: 1320px; }

.lwpt-header--container-full   .lwpt-header__inner { max-width: 100%; padding-inline: 24px; }

.lwpt-nav > li > a { font-size: var(--lwpt-nav-size, 14px); }

.lwpt-header__nav .lwpt-nav { gap: var(--lwpt-nav-gap, 24px); }

/* ── Dropdown submenus (desktop) ────────────────────────────────
       The default theme markup wraps each top-level link in a `<li>`
       and nests its children under `ul.sub-menu`. Without explicit
       absolute positioning the submenu lives inline and pushes the
       parent label above its siblings — so make every submenu an
       absolutely-positioned popover that's hidden by default and
       revealed on hover/focus-within of its parent. */

.lwpt-nav, .lwpt-nav ul { list-style: none; margin: 0; padding: 0; }

.lwpt-nav > li { position: relative; }

.lwpt-nav li.menu-item-has-children { position: relative; }

.lwpt-nav .sub-menu, .lwpt-nav ul ul {
        position: absolute;
        top: calc(100% + 10px);
        left: 0;
        min-width: 220px;
        padding: 8px;
        margin: 0;
        list-style: none;
        background: var(--lwpt-submenu-bg, #fff);
        color: var(--lwpt-submenu-text, #0f172a);
        border: 1px solid var(--lwpt-color-border, #e5e7eb);
        border-radius: var(--lwpt-submenu-radius, 12px);
        box-shadow:
            0 1px 2px rgba(15, 23, 42, .04),
            0 8px 28px rgba(15, 23, 42, .10),
            0 24px 60px -16px rgba(15, 23, 42, .12);
        opacity: 0;
        visibility: hidden;
        transform: translateY(-6px) scale(.98);
        transform-origin: top left;
        transition: opacity .18s ease, transform .2s cubic-bezier(.2, .9, .3, 1.2), visibility .18s;
        pointer-events: none;
        z-index: 50;
    }

.lwpt-nav > li.menu-item-has-children:hover > .sub-menu,
    .lwpt-nav > li.menu-item-has-children:focus-within > .sub-menu,
    .lwpt-nav li.menu-item-has-children:hover > .sub-menu,
    .lwpt-nav li.menu-item-has-children:focus-within > .sub-menu {
        opacity: 1;
        visibility: visible;
        transform: translateY(0) scale(1);
        pointer-events: auto;
    }

/* Hover-bridge — invisible 10px buffer between the parent label and
       the popover so the dropdown doesn't dismiss as the cursor crosses
       the gap. Pseudo-element so it never affects layout. */

.lwpt-nav > li.menu-item-has-children::before {
        content: "";
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        height: 10px;
        background: transparent;
        pointer-events: auto;
    }

.lwpt-nav > li.menu-item-has-children:not(:hover):not(:focus-within)::before {
        pointer-events: none;
    }

/* Submenu items */

.lwpt-nav .sub-menu li { display: block; margin: 0; }

.lwpt-nav .sub-menu a {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 9px 14px;
        margin: 1px 0;
        border-radius: 8px;
        font-size: 14px;
        font-weight: 500;
        line-height: 1.45;
        color: var(--lwpt-submenu-text, #0f172a);
        text-decoration: none;
        white-space: nowrap;
        transition: background .15s ease, color .15s ease, transform .15s ease;
    }

.lwpt-nav .sub-menu a:hover,
    .lwpt-nav .sub-menu a:focus-visible {
        background: color-mix(in srgb, var(--lwpt-color-primary, #6366f1) 10%, transparent);
        color: var(--lwpt-submenu-hover, var(--lwpt-color-primary, #6366f1));
        transform: translateX(2px);
    }

.lwpt-nav .sub-menu .current-menu-item > a {
        color: var(--lwpt-color-primary, #6366f1);
        background: color-mix(in srgb, var(--lwpt-color-primary, #6366f1) 6%, transparent);
        font-weight: 600;
    }

/* Chevron indicator on parent items — flat-icon style.
       Uses an inline SVG mask so the glyph picks up `currentColor` and
       can be tinted by any theme palette without re-encoding the SVG. */

.lwpt-nav li.menu-item-has-children > a {
        display: inline-flex;
        align-items: center;
        gap: 5px;
    }

.lwpt-nav li.menu-item-has-children > a::after {
        content: "";
        width: 12px;
        height: 12px;
        flex-shrink: 0;
        background-color: currentColor;
        -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") center/contain no-repeat;
                mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") center/contain no-repeat;
        opacity: .55;
        transition: transform .22s cubic-bezier(.2, .9, .3, 1.2), opacity .2s ease;
    }

.lwpt-nav > li.menu-item-has-children:hover > a::after,
    .lwpt-nav > li.menu-item-has-children:focus-within > a::after {
        transform: rotate(180deg);
        opacity: 1;
    }

/* Third-level: chevron points right, rotates further on hover. */

.lwpt-nav .sub-menu li.menu-item-has-children > a::after {
        margin-left: auto;
        transform: rotate(-90deg);
    }

.lwpt-nav .sub-menu li.menu-item-has-children:hover > a::after,
    .lwpt-nav .sub-menu li.menu-item-has-children:focus-within > a::after {
        transform: rotate(-90deg) translateX(2px);
        opacity: 1;
    }

.lwpt-nav .sub-menu .sub-menu {
        top: -8px;
        left: calc(100% + 6px);
        transform: translateX(-6px) scale(.98);
        transform-origin: top left;
    }

.lwpt-nav .sub-menu li.menu-item-has-children:hover > .sub-menu,
    .lwpt-nav .sub-menu li.menu-item-has-children:focus-within > .sub-menu {
        transform: translateX(0) scale(1);
    }

/* Right-edge guard: if the parent <li> sits past 70% of the header,
       open the dropdown to the LEFT instead of the right so it never
       overflows the viewport. */

.lwpt-header__inner .lwpt-nav > li.menu-item-has-children:nth-last-child(-n+2) > .sub-menu { left: auto; right: 0; transform-origin: top right; }

.lwpt-header__inner .lwpt-nav > li.menu-item-has-children:nth-last-child(-n+2) .sub-menu .sub-menu { left: auto; right: calc(100% + 6px); transform-origin: top right; }

/* Shadow variants — saved through the customizer. */

.lwpt-header--submenu-shadow-soft   .lwpt-nav .sub-menu { box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 4px 12px rgba(15,23,42,.06); }

.lwpt-header--submenu-shadow-medium .lwpt-nav .sub-menu { box-shadow: 0 4px 8px rgba(15,23,42,.08), 0 12px 32px rgba(15,23,42,.12); }

.lwpt-header--submenu-shadow-hard   .lwpt-nav .sub-menu { box-shadow: 0 12px 24px rgba(15,23,42,.16), 0 32px 64px rgba(15,23,42,.20); }

/* Mobile: collapse submenu inline (drawer territory). On narrow
       viewports we don't want hover popovers — let the mobile drawer
       handle its own accordion. */

@media (max-width: 960px) {
        .lwpt-header__nav .lwpt-nav .sub-menu {
            position: static;
            opacity: 1;
            visibility: visible;
            transform: none;
            box-shadow: none;
            border: 0;
            background: transparent;
            pointer-events: auto;
            padding: 4px 0 4px 16px;
            min-width: 0;
        }
    }

.lwpt-announce { font-size: var(--lwpt-announce-size, 13px); font-weight: var(--lwpt-announce-weight, 500); }

.lwpt-announce--bottom { position: fixed; left: 0; right: 0; bottom: 0; z-index: 100; }

.lwpt-cta--sm { padding: 6px 14px; font-size: 13px; }

.lwpt-cta--md { padding: 9px 18px; font-size: 14px; }

.lwpt-cta--lg { padding: 12px 24px; font-size: 15px; }

.lwpt-drawer .lwpt-drawer__panel { width: var(--lwpt-mobile-drawer-w, 320px); background: var(--lwpt-mobile-drawer-bg, #fff); color: var(--lwpt-mobile-drawer-text, #0f172a); }

body:not(.lwpt-header-shadow) .lwpt-header { box-shadow: none; }

.lwpt-header-shadow .lwpt-header { box-shadow: 0 1px 3px rgba(15,23,42,0.06); }

.lwpt-header:where(:not(.lwpt-header--stacked)) .lwpt-header__inner { min-height: var(--lwpt-header-h, 64px); }

.lwpt-header.is-scrolled { box-shadow: 0 2px 14px rgba(15,23,42,0.08); }

.lwpt-header a  { color: inherit; }

.lwpt-header a:hover,
    .lwpt-header .lwpt-nav a:hover { color: var(--lwpt-header-hover, #4f46e5); }

/* Logo size */

.lwpt-header__brand .custom-logo,
    .lwpt-header__brand img { max-width: var(--lwpt-logo-maxw, 180px); max-height: calc(var(--lwpt-header-h, 64px) - 16px); width: auto; height: auto; -o-object-fit: contain; object-fit: contain; }

.lwpt-header__brand { display: flex; flex-direction: column; gap: 2px; }

.lwpt-header__tagline { font-size: 11px; color: color-mix(in srgb, currentColor 60%, transparent); letter-spacing: 0.04em; }

/* Nav case + weight */

.lwpt-nav a {
        font-weight: var(--lwpt-nav-weight, 500);
        text-transform: var(--lwpt-nav-case, none);
    }

/* ─── Modern header ──────────────────────────────────────────────── */

.lwpt-header--modern .lwpt-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.lwpt-header--modern .lwpt-header__right {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.lwpt-header--modern .lwpt-header__nav .lwpt-nav {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

/* ─── Stacked header ─────────────────────────────────────────────── */

.lwpt-header--stacked .lwpt-header__top    { border-bottom: 1px solid var(--lwpt-color-border, #e2e8f0); }

.lwpt-header--stacked .lwpt-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
}

.lwpt-header--stacked .lwpt-header__bottom { padding: 6px 0; }

.lwpt-header--stacked .lwpt-header__nav--full .lwpt-nav {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
}

/* ─── Nav hover effects ──────────────────────────────────────────── */

.lwpt-theme[class*="header-nav-hover-color"]     .lwpt-nav a:hover { color: var(--lwpt-header-hover, #4f46e5); }

.lwpt-nav a { position: relative; }

.lwpt-theme .lwpt-header .lwpt-nav a::after     { content: none; }

/* underline slide-in */

body[data-lwpt-nav-hover="underline"] .lwpt-nav > li > a { position: relative; }

body[data-lwpt-nav-hover="underline"] .lwpt-nav > li > a::after {
        content: ''; position: absolute; left: 0; right: 0; bottom: 2px;
        height: 2px; background: var(--lwpt-header-hover, #4f46e5);
        transform: scaleX(0); transform-origin: left; transition: transform 0.22s;
    }

body[data-lwpt-nav-hover="underline"] .lwpt-nav > li > a:hover::after,
    body[data-lwpt-nav-hover="underline"] .lwpt-nav > li.current-menu-item > a::after { transform: scaleX(1); }

/* highlight pill */

body[data-lwpt-nav-hover="highlight"] .lwpt-nav > li > a {
        padding: 6px 10px; border-radius: 8px; transition: background 0.18s;
    }

body[data-lwpt-nav-hover="highlight"] .lwpt-nav > li > a:hover,
    body[data-lwpt-nav-hover="highlight"] .lwpt-nav > li.current-menu-item > a {
        background: color-mix(in srgb, var(--lwpt-header-hover, #4f46e5) 10%, transparent);
        color: var(--lwpt-header-hover, #4f46e5);
    }

/* bar below */

body[data-lwpt-nav-hover="bar-below"] .lwpt-nav > li > a { border-bottom: 2px solid transparent; }

body[data-lwpt-nav-hover="bar-below"] .lwpt-nav > li > a:hover,
    body[data-lwpt-nav-hover="bar-below"] .lwpt-nav > li.current-menu-item > a { border-bottom-color: var(--lwpt-header-hover, #4f46e5); }

/* ─── CTA outlined / ghost ───────────────────────────────────────── */

.lwpt-btn--outlined {
  border-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  background-color: transparent;
  color: var(--lwpt-color-text, #0f172a);
}

.lwpt-btn--outlined:hover {
  border-color: var(--lwpt-color-primary, #4f46e5);
  color: var(--lwpt-color-primary, #4f46e5); background: transparent;
}

.lwpt-btn--ghost {
  border-width: 0px;
  background-color: transparent;
  color: var(--lwpt-color-text, #0f172a);
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.lwpt-btn--ghost:hover {
  color: var(--lwpt-color-primary, #4f46e5);
}

/* ─── Mobile drawer ──────────────────────────────────────────────── */

/* Drawer must paint ABOVE the header. Header is z-9000 (set in
       header.php inline failsafe + here for redundancy). */

.lwpt-drawer { position: fixed; inset: 0; z-index: 9500 !important; visibility: hidden; }

.lwpt-header { z-index: 9000; }

body.lwpt-has-menu .lwpt-header { z-index: 8999 !important; }

.lwpt-drawer:not([hidden]) { visibility: visible; }

.lwpt-drawer__backdrop {
  position: absolute;
  inset: 0px;
  background-color: rgb(0 0 0 / 0.4);
        opacity: 0; transition: opacity 0.24s;
}

.lwpt-drawer.is-open .lwpt-drawer__backdrop { opacity: 1; }

.lwpt-drawer__panel {
  position: absolute;
  top: 0px;
  bottom: 0px;
  display: flex;
  flex-direction: column;
  background-color: var(--lwpt-color-bg, #ffffff);
        width: min(360px, 88vw);
        padding: 16px 20px 24px;
        box-shadow: 0 0 40px rgba(0,0,0,0.18);
        transform: translateX(100%); transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
        overflow-y: auto;
}

.lwpt-drawer--drawer-right .lwpt-drawer__panel { right: 0; transform: translateX(100%); }

.lwpt-drawer--drawer-left  .lwpt-drawer__panel { left:  0; transform: translateX(-100%); }

.lwpt-drawer.is-open .lwpt-drawer__panel { transform: translateX(0); }

.lwpt-drawer--fullscreen .lwpt-drawer__panel {
  inset: 0px;
  width: 100%; transform: translateY(-100%);
}

.lwpt-drawer--fullscreen.is-open .lwpt-drawer__panel { transform: translateY(0); }

.lwpt-drawer--dropdown .lwpt-drawer__panel {
  top: 0px;
  right: 0px;
  left: 0px;
  width: 100%;
  max-width: none;
        transform: translateY(-110%); box-shadow: 0 10px 40px rgba(0,0,0,0.12);
}

.lwpt-drawer--dropdown.is-open .lwpt-drawer__panel { transform: translateY(0); }

.lwpt-drawer__header {
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
  padding-bottom: 1rem;
}

.lwpt-drawer__nav .lwpt-nav,
    .lwpt-drawer__secondary .lwpt-nav {
  flex-direction: column;
  align-items: stretch;
  gap: 0px;
}

.lwpt-drawer__nav .lwpt-nav li {
  border-bottom-width: 1px;
  border-color: var(--lwpt-color-border, #e2e8f0);
}

.lwpt-drawer__nav .lwpt-nav a {
  display: block;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem; font-size: 16px;
}

.lwpt-drawer__nav .sub-menu {
  margin: 0px;
  list-style-type: none;
  padding-left: 1rem;
}

.lwpt-drawer__secondary {
  margin-top: 1.5rem;
}

.lwpt-drawer__social {
  margin-top: auto;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding-top: 1.5rem;
}

body.lwpt-has-menu { overflow: hidden; }

/* ─── Responsive: show/hide nav at the mobile breakpoint ─────────── */

.lwpt-header__nav { display: none; }

@media (min-width: 961px) {
        .lwpt-header__nav { display: block; flex: 1; }
        .lwpt-hamburger   { display: none; }
    }

.lwpt-header--default .lwpt-header__nav .lwpt-nav-wrap {
  display: flex;
  justify-content: center;
}

/* ─── Responsive tuning across the board ─────────────────────────── */

@media (max-width: 960px) {
        .lwpt-header__inner { gap: 0.75rem; }
        .lwpt-header--stacked .lwpt-header__bottom { display: none; }
        .lwpt-header__tagline { display: none; }
    }

/* Title + prose */

@media (max-width: 640px) {
        .lwpt-entry-title { font-size: clamp(1.6rem, 6vw, 2.1rem) !important; line-height: 1.2; }
        .lwpt-archive-title { font-size: clamp(1.5rem, 5vw, 2rem); }
        .lwpt-prose { font-size: 16.5px; }
        .lwpt-prose h2 { font-size: 1.4rem; }
        .lwpt-prose h3 { font-size: 1.2rem; }
    }

/* Meta — wrap nicely, smaller gap on mobile */

@media (max-width: 560px) {
        .lwpt-meta { font-size: 13px; gap: 4px 6px; }
        .lwpt-meta .lwpt-meta__sep { margin-inline: 2px; }
    }

/* Social share — horizontal scroll on tiny screens */

@media (max-width: 520px) {
        .lwpt-social-share {
    flex-wrap: wrap; padding: 10px 0;
  }
        .lwpt-social-share__list {
    flex-wrap: wrap;
    gap: 0.375rem;
  }
        .lwpt-social-share--floating { display: none !important; }
    }

/* Post-navigation — always stack on mobile */

@media (max-width: 720px) {
        .lwpt-post-nav { grid-template-columns: 1fr !important; }
        .lwpt-post-nav__link--next { text-align: left !important; flex-direction: row !important; }
    }

/* Related posts — 2 cols on tablet, 1 on phone */

@media (max-width: 720px) {
        .lwpt-related__wrap { grid-template-columns: 1fr 1fr !important; }
        .lwpt-related--list .lwpt-related__card { grid-template-columns: 100px 1fr; }
    }

@media (max-width: 480px) {
        .lwpt-related__wrap { grid-template-columns: 1fr !important; }
        .lwpt-related--carousel .lwpt-related__card { flex: 0 0 260px; }
    }

/* Archive grid — safe 1-col fallback on phones */

@media (max-width: 640px) {
        .lwpt-archive-grid,
        .lwpt-archive-grid--2,
        .lwpt-archive-grid--3,
        .lwpt-archive-grid--4 { grid-template-columns: 1fr !important; }
        .lwpt-card--list,
        .lwpt-acard-horizontal .lwpt-card { grid-template-columns: 1fr !important; }
        .lwpt-archive-magazine__feature .lwpt-card { grid-template-columns: 1fr !important; }
    }

/* Single — always stack single+sidebar on tablet */

@media (max-width: 960px) {
        .lwpt-single--right-sidebar,
        .lwpt-single--left-sidebar,
        .lwpt-sbar-right-sidebar,
        .lwpt-sbar-left-sidebar { grid-template-columns: 1fr !important; }
        .lwpt-sidebar--sticky { position: static; }
    }

/* Featured behind-title — shorter on mobile */

@media (max-width: 720px) {
        .lwpt-featured--behind-title img { aspect-ratio: 4/3; }
        .lwpt-featured--bleed img { height: 32vh; }
    }

/* Footer cols — stack at tablet, grid at desktop */

@media (max-width: 720px) {
        .lwpt-footer__cols--2,
        .lwpt-footer__cols--3,
        .lwpt-footer__cols--4 { grid-template-columns: 1fr !important; }
        .lwpt-footer__cols { padding-block: 2.5rem; gap: 2.25rem; }
        .lwpt-footer__bar  { flex-direction: column; text-align: center; }
    }

/* TOC — collapse on mobile by default */

@media (max-width: 720px) {
        .lwpt-toc { position: static !important; width: auto !important; }
        .lwpt-toc--floating { display: none; }
    }

/* Author box — stack vertically on phone */

@media (max-width: 560px) {
        .lwpt-author-box { flex-direction: column; text-align: center; }
        .lwpt-author-box--centered .lwpt-author-box__avatar { margin-inline: auto; }
    }

/* Fluid heading sizes */

:root { --lwpt-h1: clamp(2rem, 4vw, 2.75rem); --lwpt-h2: clamp(1.5rem, 3vw, 2rem); --lwpt-h3: clamp(1.25rem, 2.4vw, 1.5rem); }

/* ─── Header-scroll shrink ───────────────────────────────────────── */

.lwpt-header.is-scrolled:where(.lwpt-header--default, .lwpt-header--modern, .lwpt-header--stacked) .lwpt-header__inner { min-height: calc(var(--lwpt-header-h, 64px) - 8px); }

/* ─── Single post design presets (bundled visual overrides) ──────── */

body.lwpt-preset-minimal .lwpt-entry-title { font-weight: 700; letter-spacing: -0.03em; }

body.lwpt-preset-minimal .lwpt-single    { padding-block: 3rem; }

body.lwpt-preset-minimal .lwpt-meta      { font-size: 12.5px; letter-spacing: 0.04em; text-transform: uppercase; }

body.lwpt-preset-minimal .lwpt-prose     { font-family: Georgia, 'Iowan Old Style', serif; font-size: 18px; }

body.lwpt-preset-longread .lwpt-prose > p:first-of-type::first-letter {
        float: left; font-family: var(--lwpt-font-heading, Inter); font-size: 4.8em; line-height: 0.85;
        padding: 0.15em 0.12em 0 0; font-weight: 900; color: var(--lwpt-color-primary, #4f46e5);
    }

body.lwpt-preset-longread .lwpt-entry-title { font-size: clamp(2.4rem, 5vw, 3.4rem); letter-spacing: -0.03em; }

body.lwpt-preset-magazine .lwpt-entry-header { text-align: center; padding-block: 2rem; }

body.lwpt-preset-magazine .lwpt-featured--bleed img { height: 60vh; }

body.lwpt-preset-editorial .lwpt-entry-title { font-family: Georgia, 'Iowan Old Style', serif; font-weight: 800; }

body.lwpt-preset-editorial .lwpt-prose h2,
    body.lwpt-preset-editorial .lwpt-prose h3 { font-family: Georgia, 'Iowan Old Style', serif; }

body.lwpt-preset-editorial .lwpt-title-area { text-align: center; }

body.lwpt-preset-editorial .lwpt-title-area__meta { justify-content: center; }

body.lwpt-preset-news .lwpt-entry-title { font-size: clamp(1.75rem, 3.5vw, 2.25rem); }

body.lwpt-preset-news .lwpt-single    { padding-block: 1.5rem; }

body.lwpt-preset-news .lwpt-entry-header { margin-bottom: 1.5rem; }

body.lwpt-preset-review .lwpt-entry { background: var(--lwpt-color-bg, #fff); border: 1px solid var(--lwpt-color-border, #e2e8f0); border-radius: 14px; padding: clamp(1.25rem, 3vw, 2.5rem); box-shadow: 0 1px 3px rgba(15,23,42,0.05); }

body.lwpt-preset-journal .lwpt-prose { font-family: 'Iowan Old Style', Georgia, serif; font-size: 18.5px; line-height: 1.8; }

body.lwpt-preset-journal .lwpt-entry-title { font-family: 'Iowan Old Style', Georgia, serif; font-weight: 700; }

.lwpt-container {
        padding-left:  var(--lwpt-space-container-x, 20px);
        padding-right: var(--lwpt-space-container-x, 20px);
    }

/* Primary button uses the button-color tokens.
       The selectors include :link/:visited because anchors with the
       `.lwpt-btn` class otherwise inherit global link colors and the
       button text disappears against its background (low contrast). */

a.lwpt-btn--primary,
    a.lwpt-btn--primary:link,
    a.lwpt-btn--primary:visited,
    .lwpt-btn--primary {
        background: var(--lwpt-color-btn-bg, var(--lwpt-color-primary, #4f46e5));
        color:      var(--lwpt-color-btn-text, #fff);
    }

a.lwpt-btn--primary:hover,
    a.lwpt-btn--primary:focus,
    a.lwpt-btn--primary:active,
    .lwpt-btn--primary:hover {
        background: var(--lwpt-color-btn-hover, var(--lwpt-color-link-hover, #4338ca));
        color:      var(--lwpt-color-btn-text, #fff);
    }

/* Visible keyboard focus ring — high-contrast against any button bg. */

.lwpt-btn--primary:focus-visible,
    a.lwpt-btn--primary:focus-visible {
        outline: 3px solid color-mix(in srgb, var(--lwpt-color-btn-bg, #4f46e5) 35%, #ffffff);
        outline-offset: 3px;
    }

/* Decent tap target on mobile (WCAG 2.5.5). */

.lwpt-btn { min-height: 40px; }

/* Boxed single container uses card-bg */

.lwpt-csty-boxed .lwpt-entry,
    .lwpt-clay-boxed,
    body.lwpt-preset-review .lwpt-entry {
        background: var(--lwpt-color-card-bg, #fff);
        padding: var(--lwpt-space-card-pad, 28px);
    }

/* Section rhythm — archive title, related posts, author box, comments */

.lwpt-archive-header,
    .lwpt-related,
    .lwpt-comments,
    .lwpt-author-box        { margin-block: var(--lwpt-space-section-y, 80px); }

.lwpt-archive-header    { margin-top: 0; }

/* Single entry-gap */

.lwpt-single > *        { row-gap: 0; }

.lwpt-entry             { margin-bottom: var(--lwpt-space-entry-gap, 40px); }

.lwpt-related,
    .lwpt-author-box        { margin-top: var(--lwpt-space-entry-gap, 40px); }

/* Paragraph / prose spacing */

.lwpt-prose p           { margin-block: var(--lwpt-space-para-gap, 20px); }

.lwpt-prose h2          { margin-top: var(--lwpt-space-heading-top, 40px); margin-bottom: 16px; }

.lwpt-prose h3          { margin-top: calc(var(--lwpt-space-heading-top, 40px) * 0.75); margin-bottom: 12px; }

/* Card gap for archive grid */

.lwpt-archive-grid      { gap: var(--lwpt-card-gap, 24px); }

/* Card padding for archive cards */

.lwpt-card__body        { padding: var(--lwpt-space-card-pad, 28px); }

/* Surfaces */

.lwpt-footer,
    .lwpt-widget,
    .lwpt-author-box,
    .lwpt-toc,
    .lwpt-post-nav__link,
    .lwpt-related__card     { background: var(--lwpt-color-bg-alt, #f8fafc); }

.lwpt-card,
    .lwpt-sbs-boxed .lwpt-widget { background: var(--lwpt-color-card-bg, #fff); }

/* Meta + muted typography pulls from muted token */

.lwpt-reading-time, .lwpt-card__meta,
    .lwpt-card__excerpt, .lwpt-related__excerpt,
    .lwpt-footer__copyright,
    .lwpt-archive-desc, .lwpt-archive-count {
        color: var(--lwpt-color-muted, #64748b);
    }

/* Meta + breadcrumbs: respect the user's customizer color first, fall
       through to the muted token. Listed separately because the .lwpt-single-
       scoped rules below don't apply when the title area renders OUTSIDE the
       .lwpt-single container (any bg/full-width title). */

.lwpt-meta { color: var(--lwpt-s-meta-text, var(--lwpt-color-muted, #64748b)); }

.lwpt-breadcrumbs__list { color: var(--lwpt-s-bc-color, var(--lwpt-color-muted, #64748b)); }

/* Prose links — respect link-style choice on the body class */

body.lwpt-link-underline .lwpt-prose a { text-decoration: underline; }

body.lwpt-link-color     .lwpt-prose a { text-decoration: none; color: var(--lwpt-color-link, var(--lwpt-color-primary)); }

body.lwpt-link-dotted    .lwpt-prose a { -webkit-text-decoration: underline dotted; text-decoration: underline dotted; text-underline-offset: 3px; }

/* Content-image styles tied to the body classes set from Customizer */

body.lwpt-content-images-rounded .lwpt-prose img { border-radius: 14px; }

body.lwpt-content-images-shadow  .lwpt-prose img { box-shadow: 0 10px 30px rgba(0,0,0,0.10); }

/* Category badge uses primary color-mix */

.lwpt-meta__cat,
    .lwpt-card__cat--above,
    .lwpt-card__cat--overlay,
    .lwpt-related__cat {
        background: color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 12%, transparent);
        color: var(--lwpt-color-primary, #4f46e5);
    }

.lwpt-card__cat--overlay { background: var(--lwpt-color-primary, #4f46e5); color: #fff; }

/* Borders everywhere read the border token */

.lwpt-card,
    .lwpt-related__card,
    .lwpt-post-nav__link,
    .lwpt-widget,
    .lwpt-author-box,
    .lwpt-toc,
    .lwpt-meta__cat,
    .lwpt-footer,
    .lwpt-archive__content,
    .lwpt-clay-boxed,
    .lwpt-social-share__link {
        border-color: var(--lwpt-color-border, #e2e8f0);
    }

/* ─── Article container / card ────────────────────────────────────── */

body.single { background: var(--lwpt-s-bg, var(--lwpt-color-bg, #fff)); }

.lwpt-single { padding-top: var(--lwpt-s-top-pad, 40px); padding-bottom: var(--lwpt-s-bot-pad, 40px); }

/* Outer container — width override + side padding + alignment */

body.single .lwpt-container,
    body.page   .lwpt-container { padding-inline: var(--lwpt-s-container-pad-x, 1.25rem); }

body.single .lwpt-container:not(.lwpt-container--unscoped) { max-width: var(--lwpt-s-container-maxw, var(--lwpt-content-width, 1200px)); }

body.lwpt-container-align-left   .lwpt-container:not(.lwpt-container--unscoped) { margin-inline: 0 auto; }

body.lwpt-container-align-right  .lwpt-container:not(.lwpt-container--unscoped) { margin-inline: auto 0; }

body.lwpt-container-align-center .lwpt-container:not(.lwpt-container--unscoped) { margin-inline: auto; }

.lwpt-csty-boxed .lwpt-entry {
        background: var(--lwpt-s-card-bg, var(--lwpt-color-card-bg, #fff));
        color: var(--lwpt-s-card-text, inherit);
        border-radius: var(--lwpt-s-card-radius, 16px);
        padding-block: var(--lwpt-s-card-pad, 48px);
        padding-inline: var(--lwpt-s-card-pad-x, var(--lwpt-s-card-pad, 48px));
        border: var(--lwpt-s-card-border, none);
        box-shadow: var(--lwpt-s-card-shadow, 0 1px 2px rgba(15,23,42,.04), 0 8px 24px rgba(15,23,42,.06));
        position: relative;
        transition: transform .25s cubic-bezier(.4,0,.2,1), box-shadow .25s;
    }

/* Pull-up — overlap the article card over a featured-image hero */

body.lwpt-csty-boxed .lwpt-entry,
    .lwpt-csty-boxed .lwpt-entry { margin-top: calc(-1 * var(--lwpt-s-card-pull-up, 0px)); }

.lwpt-featured--bleed + .lwpt-container .lwpt-entry,
    .lwpt-featured--behind-title + .lwpt-container .lwpt-entry { margin-top: calc(-1 * var(--lwpt-s-card-pull-up, 0px)); }

/* Card fill variants — overrides the solid background when active. */

body.lwpt-card-fill-gradient .lwpt-csty-boxed .lwpt-entry {
        background: linear-gradient(180deg, var(--lwpt-s-card-bg, #fff), var(--lwpt-s-card-bg-2, var(--lwpt-color-bg-alt, #f8fafc)));
    }

body.lwpt-card-fill-glass .lwpt-csty-boxed .lwpt-entry {
        background: color-mix(in srgb, var(--lwpt-s-card-bg, #fff) 70%, transparent);
        backdrop-filter: blur(var(--lwpt-s-card-blur, 12px)) saturate(1.4);
        -webkit-backdrop-filter: blur(var(--lwpt-s-card-blur, 12px)) saturate(1.4);
    }

/* Hover lift */

body.lwpt-card-lift .lwpt-csty-boxed .lwpt-entry:hover {
        transform: translateY(-3px);
        box-shadow: 0 2px 4px rgba(15,23,42,.05), 0 18px 40px rgba(15,23,42,.10);
    }

/* Inner dividers between major article sections */

body.lwpt-card-dividers .lwpt-csty-boxed .lwpt-entry > .lwpt-title-area,
    body.lwpt-card-dividers .lwpt-csty-boxed .lwpt-entry > .lwpt-featured,
    body.lwpt-card-dividers .lwpt-csty-boxed .lwpt-entry > .lwpt-entry-content {
        border-bottom: 1px solid var(--lwpt-color-border, #e2e8f0);
        padding-bottom: 1.5rem;
        margin-bottom: 1.5rem;
    }

body.lwpt-card-dividers .lwpt-csty-boxed .lwpt-entry > .lwpt-entry-content:last-child { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }

/* ─── Title area ──────────────────────────────────────────────────── */

.lwpt-entry-title {
        color: var(--lwpt-s-title-color, var(--lwpt-color-heading));
    }

.lwpt-single .lwpt-entry-title[style*="font-size"]:not([style*="font-size:0"]) { font-size: var(--lwpt-s-title-size); }

body.single:not([class*="title-size-0"]) .lwpt-entry-title {
        font-size: var(--lwpt-s-title-size, clamp(1.9rem, 5vw, var(--lwpt-h1-size, 44px)));
    }

.lwpt-title-area { padding-block: var(--lwpt-s-title-pad-y, 0); }

.lwpt-title-area--centered .lwpt-entry-title::after {
        background: var(--lwpt-s-title-accent, var(--lwpt-color-primary, #4f46e5));
    }

.lwpt-title-area--banner {
        background: var(--lwpt-s-title-banner-bg, var(--lwpt-color-bg-alt, #f8fafc));
        color:      var(--lwpt-s-title-banner-text, var(--lwpt-color-text, #0f172a));
    }

.lwpt-title-area--banner .lwpt-entry-title { color: var(--lwpt-s-title-banner-text, inherit); }

/* ─── Featured image ──────────────────────────────────────────────── */

.lwpt-featured--rounded img,
    .lwpt-featured--rounded { border-radius: var(--lwpt-s-feat-radius, 14px); }

.lwpt-featured--rounded img                  { border-radius: var(--lwpt-s-feat-radius, 14px); }

.lwpt-single .lwpt-featured img              { max-height: var(--lwpt-s-feat-max-h, none); }

.lwpt-featured--behind-title img             { filter: brightness(calc(1 - var(--lwpt-s-feat-overlay, 0.45))); }

/* ─── Meta ────────────────────────────────────────────────────────── */

.lwpt-single .lwpt-meta {
        color: var(--lwpt-s-meta-text, var(--lwpt-color-muted));
        font-size: var(--lwpt-s-meta-size, 14px);
    }

.lwpt-single .lwpt-meta .lwpt-meta__sep { color: var(--lwpt-s-meta-sep, var(--lwpt-color-border)); }

.lwpt-single .lwpt-meta a              { color: var(--lwpt-s-meta-link, var(--lwpt-color-muted)); }

.lwpt-single .lwpt-meta a:hover        { color: var(--lwpt-s-meta-link, var(--lwpt-color-primary)); }

.lwpt-single .lwpt-meta__cat {
        background: var(--lwpt-s-meta-cat-bg, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 12%, transparent));
        color:      var(--lwpt-s-meta-cat-text, var(--lwpt-color-primary));
    }

/* ─── Reading time ────────────────────────────────────────────────── */

.lwpt-reading-time {
        color: var(--lwpt-s-rt-color, var(--lwpt-color-muted));
    }

.lwpt-reading-time svg { color: var(--lwpt-s-rt-icon, var(--lwpt-color-primary)); }

body.single .lwpt-reading-time { /* style-based tweaks set via class, default inline */ }

/* reading-time style variants — set via CSS class on body: lwpt-rt-style-pill etc. */

body.lwpt-rt-style-pill    .lwpt-reading-time,
    body.lwpt-rt-style-outlined .lwpt-reading-time {
        padding: 4px 12px; border-radius: 50px;
    }

body.lwpt-rt-style-pill     .lwpt-reading-time {
        background: var(--lwpt-s-rt-bg, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 10%, transparent));
    }

body.lwpt-rt-style-outlined .lwpt-reading-time {
        background: var(--lwpt-s-rt-bg, transparent);
        border: 1px solid var(--lwpt-color-border, #e2e8f0);
    }

/* ─── Content prose ──────────────────────────────────────────────── */

.lwpt-single .lwpt-prose          { color: var(--lwpt-s-content-text, var(--lwpt-color-text)); }

.lwpt-single .lwpt-prose h1,
    .lwpt-single .lwpt-prose h2,
    .lwpt-single .lwpt-prose h3,
    .lwpt-single .lwpt-prose h4       { color: var(--lwpt-s-content-heading, var(--lwpt-color-heading, var(--lwpt-color-text))); }

.lwpt-single .lwpt-prose a        { color: var(--lwpt-s-content-link, var(--lwpt-color-link, var(--lwpt-color-primary))); }

.lwpt-single .lwpt-prose a:hover  { color: var(--lwpt-s-content-link-h, var(--lwpt-color-link-hover)); }

.lwpt-single .lwpt-prose blockquote {
        background: var(--lwpt-s-quote-bg, transparent);
        border-left-color: var(--lwpt-s-quote-border, color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 35%, transparent));
        padding: 1rem 1.25rem;
    }

.lwpt-single .lwpt-prose pre,
    .lwpt-single .lwpt-prose code {
        background: var(--lwpt-s-code-bg, #0f172a);
        color:      var(--lwpt-s-code-text, #f8fafc);
    }

.lwpt-single .lwpt-prose :not(pre) > code { padding: 2px 6px; border-radius: 4px; }

/* Heading accent bar */

body.single:where([style*="--lwpt-s-heading-accent"]) .lwpt-prose h2 {
        padding-left: 14px; border-left: 4px solid var(--lwpt-color-primary, #4f46e5); border-radius: 2px;
    }

/* ─── Social share ────────────────────────────────────────────────── */

.lwpt-single .lwpt-social-share {
        padding: var(--lwpt-s-soc-pad-y, 16px) 0;
        background: var(--lwpt-s-soc-bg, transparent);
    }

body.lwpt-s-soc-border-top    .lwpt-social-share { border-top: 1px solid var(--lwpt-s-soc-border, var(--lwpt-color-border)); }

body.lwpt-s-soc-border-bottom .lwpt-social-share { border-bottom: 1px solid var(--lwpt-s-soc-border, var(--lwpt-color-border)); }

.lwpt-single .lwpt-social-share__link {
        color: var(--lwpt-s-soc-icon, var(--lwpt-color-text));
        border-color: var(--lwpt-s-soc-border, var(--lwpt-color-border));
    }

.lwpt-single .lwpt-social-share__link:hover {
        background: var(--lwpt-s-soc-hover-bg, var(--lwpt-color-bg-alt));
        color: var(--lwpt-s-soc-hover-color, var(--lwpt-color-primary));
        border-color: var(--lwpt-s-soc-hover-color, var(--lwpt-color-primary));
    }

/* ─── TOC ────────────────────────────────────────────────────────── */

.lwpt-single .lwpt-toc {
        background: var(--lwpt-s-toc-bg, var(--lwpt-color-bg-alt));
        border-color: var(--lwpt-s-toc-border, var(--lwpt-color-border));
        border-radius: var(--lwpt-s-toc-radius, 14px);
    }

.lwpt-single .lwpt-toc__title-label  { color: var(--lwpt-s-toc-title, var(--lwpt-color-heading)); }

.lwpt-single .lwpt-toc__item a       { color: var(--lwpt-s-toc-link, var(--lwpt-color-text)); }

.lwpt-single .lwpt-toc__item a:hover,
    .lwpt-single .lwpt-toc__item a.is-active { color: var(--lwpt-s-toc-active, var(--lwpt-color-primary)); }

/* Make in-page anchor jumps not hide under a sticky header. */

.lwpt-single .lwpt-prose h2[id],
    .lwpt-single .lwpt-prose h3[id],
    .lwpt-single .lwpt-prose h4[id] { scroll-margin-top: 90px; }

/* ─── Author box ──────────────────────────────────────────────────── */

.lwpt-single .lwpt-author-box {
        background: var(--lwpt-s-author-bg, var(--lwpt-color-bg-alt));
        border-color: var(--lwpt-s-author-border, var(--lwpt-color-border));
        border-radius: var(--lwpt-s-author-radius, 14px);
        padding: var(--lwpt-s-author-pad, 24px);
    }

.lwpt-single .lwpt-author-box__name a { color: var(--lwpt-s-author-name, var(--lwpt-color-heading)); }

.lwpt-single .lwpt-author-box__bio    { color: var(--lwpt-s-author-bio,  var(--lwpt-color-muted)); }

.lwpt-single .lwpt-author-box__link   { color: var(--lwpt-s-author-link, var(--lwpt-color-primary)); }

/* ─── Post nav ───────────────────────────────────────────────────── */

.lwpt-single .lwpt-post-nav__link {
        background: var(--lwpt-s-nav-bg, var(--lwpt-color-bg-alt));
        border-color: var(--lwpt-s-nav-border, var(--lwpt-color-border));
        border-radius: var(--lwpt-s-nav-radius, 14px);
    }

.lwpt-single .lwpt-post-nav__link:hover { border-color: var(--lwpt-s-nav-hover-b, var(--lwpt-color-primary)); }

.lwpt-single .lwpt-post-nav__label      { color: var(--lwpt-s-nav-label, var(--lwpt-color-muted)); }

.lwpt-single .lwpt-post-nav__title      { color: var(--lwpt-s-nav-title, var(--lwpt-color-heading)); }

/* ─── Related posts ──────────────────────────────────────────────── */

.lwpt-single .lwpt-related__title      { color: var(--lwpt-s-rel-title, var(--lwpt-color-heading)); }

.lwpt-single .lwpt-related__wrap       { gap: var(--lwpt-s-rel-gap, 24px); }

.lwpt-single .lwpt-related__card {
        background: var(--lwpt-s-rel-card-bg, var(--lwpt-color-card-bg, #fff));
        border-color: var(--lwpt-s-rel-card-b, var(--lwpt-color-border));
        border-radius: var(--lwpt-s-rel-radius, 14px);
        transition: transform 0.25s, box-shadow 0.25s;
    }

.lwpt-single .lwpt-related__heading a  { color: var(--lwpt-s-rel-card-title, var(--lwpt-color-heading)); }

.lwpt-single .lwpt-related__date,
    .lwpt-single .lwpt-related__author     { color: var(--lwpt-s-rel-card-meta, var(--lwpt-color-muted)); }

body.lwpt-s-rel-hover-lift .lwpt-related__card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(15,23,42,0.08); }

/* ─── Comments ───────────────────────────────────────────────────── */

.lwpt-single .lwpt-comments__title        { color: var(--lwpt-s-com-title, var(--lwpt-color-heading)); }

.lwpt-single .lwpt-comments__list li      {
        background: var(--lwpt-s-com-bg, var(--lwpt-color-bg-alt));
        border-color: var(--lwpt-s-com-border, var(--lwpt-color-border));
    }

.lwpt-single .lwpt-comments a,
    .lwpt-single .lwpt-comments .comment-form a { color: var(--lwpt-s-com-link, var(--lwpt-color-link)); }

.lwpt-single .comment-respond             { background: var(--lwpt-s-com-form-bg, var(--lwpt-color-bg-alt)); }

/* ─── Breadcrumbs ────────────────────────────────────────────────── */

/* No .lwpt-single ancestor — the breadcrumb may render inside the
       title-area (which sits OUTSIDE the .lwpt-single container) so we
       scope to .lwpt-breadcrumbs itself. !important wins over Tailwind's
       base text-muted utility on the inner span. */

.lwpt-breadcrumbs                                                    { font-size: var(--lwpt-s-bc-size, inherit); }

.lwpt-breadcrumbs.lwpt-breadcrumbs                                   { color: var(--lwpt-s-bc-color, currentColor); }

.lwpt-breadcrumbs .lwpt-breadcrumbs__item a                          { color: var(--lwpt-s-bc-link, currentColor) !important; }

.lwpt-breadcrumbs .lwpt-breadcrumbs__item a:hover                    { color: var(--lwpt-s-bc-link-hover, var(--lwpt-color-primary, #4f46e5)) !important; opacity: .85; }

.lwpt-breadcrumbs .lwpt-breadcrumbs__item.is-current span,
    .lwpt-breadcrumbs .lwpt-breadcrumbs__item.is-current                 { color: var(--lwpt-s-bc-current, currentColor) !important; }

.lwpt-breadcrumbs .lwpt-breadcrumbs__item + .lwpt-breadcrumbs__item::before { color: var(--lwpt-s-bc-sep, currentColor); opacity: .5; }

/* Allow long current-page titles to wrap normally (the title-area has
       overflow:hidden — without flex-wrap/word-break the text gets clipped
       at the container edge instead of dropping to the next line). */

.lwpt-breadcrumbs                       { overflow: visible; }

.lwpt-breadcrumbs__list                 { flex-wrap: wrap; max-width: 100%; row-gap: 4px; }

.lwpt-breadcrumbs__item                 { min-width: 0; max-width: 100%; }

.lwpt-breadcrumbs__item span,
    .lwpt-breadcrumbs__item a               { white-space: normal; word-break: break-word; overflow-wrap: anywhere; }

/* Center alignment used to misbehave because flex-wrap dropped the
       last item to a new line that started left-aligned. justify-content
       on the flex list keeps the wrapped row centered too. */

.lwpt-breadcrumbs--align-center .lwpt-breadcrumbs__list { justify-content: center; }

.lwpt-breadcrumbs--align-right  .lwpt-breadcrumbs__list { justify-content: flex-end; }

/* ─── Inline field mode ──────────────────────────────────────────── */

.lwpt-header__searchfield {
        display: inline-flex; align-items: center; gap: 8px;
        padding: 6px 12px; border-radius: 999px;
        background: color-mix(in srgb, var(--lwpt-header-text, #0f172a) 6%, transparent);
        transition: background 0.2s, box-shadow 0.2s;
    }

.lwpt-header__searchfield:focus-within {
        background: color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 8%, transparent);
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 15%, transparent);
    }

.lwpt-header__searchfield svg { color: var(--lwpt-color-muted, #64748b); flex-shrink: 0; }

.lwpt-header__searchfield input {
        border: 0; background: transparent; outline: none; font-size: 14px; width: 180px;
        font-family: inherit; color: inherit;
    }

/* ─── Search trigger button (modal mode) ─────────────────────────── */

.lwpt-search-trigger {
        position: relative; padding-right: 10px;
    }

.lwpt-search-trigger__kbd {
        display: none;
        position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
        background: color-mix(in srgb, var(--lwpt-header-text, #0f172a) 10%, transparent);
        border: 1px solid color-mix(in srgb, var(--lwpt-header-text, #0f172a) 15%, transparent);
        border-radius: 4px; font-size: 11px; padding: 1px 5px; line-height: 1.2;
        color: var(--lwpt-color-muted, #64748b); font-family: ui-monospace, monospace;
    }

@media (min-width: 961px) { .lwpt-search-trigger__kbd { display: inline; } .lwpt-search-trigger { width: auto; padding: 8px 32px 8px 12px; border-radius: 8px; background: color-mix(in srgb, var(--lwpt-header-text, #0f172a) 5%, transparent); }
        .lwpt-search-trigger:hover { background: color-mix(in srgb, var(--lwpt-header-text, #0f172a) 10%, transparent); } }

/* ─── Search modal ───────────────────────────────────────────────── */

.lwpt-search-modal { position: fixed; inset: 0; z-index: 9999; }

.lwpt-search-modal[hidden] { display: none; }

/* CSS-only :target fallback — clicking <a href="#lwpt-search-modal">
       changes the URL hash; this rule reveals the modal even if every JS
       handler on the page is hijacked. */

.lwpt-search-modal:target { display: block !important; animation: lwpt-search-target-open .2s ease forwards; }

@keyframes lwpt-search-target-open { to {} }

/* no-op; presence triggers reflow for is-open swap */

.lwpt-search-modal__backdrop {
        position: absolute; inset: 0;
        background: rgba(15, 23, 42, 0.55); backdrop-filter: blur(4px);
        opacity: 0; transition: opacity 0.22s;
    }

.lwpt-search-modal--bg-dimmed .lwpt-search-modal__backdrop { backdrop-filter: none; }

.lwpt-search-modal--bg-none   .lwpt-search-modal__backdrop { background: transparent; backdrop-filter: none; }

.lwpt-search-modal.is-open .lwpt-search-modal__backdrop { opacity: 1; }

.lwpt-search-modal__panel {
        position: relative; max-width: 640px; margin: 8vh auto 0;
        background: var(--lwpt-color-bg, #fff);
        border: 1px solid var(--lwpt-color-border, #e2e8f0);
        border-radius: 16px;
        box-shadow: 0 20px 80px rgba(15, 23, 42, 0.25), 0 2px 8px rgba(15, 23, 42, 0.08);
        overflow: hidden;
        transform: translateY(-8px) scale(0.98); opacity: 0;
        transition: transform 0.24s cubic-bezier(0.4,0,0.2,1), opacity 0.24s;
    }

.lwpt-search-modal--w-narrow .lwpt-search-modal__panel { max-width: 480px; }

.lwpt-search-modal--w-medium .lwpt-search-modal__panel { max-width: 640px; }

.lwpt-search-modal--w-wide   .lwpt-search-modal__panel { max-width: 800px; }

.lwpt-search-modal--p-center {
        display: flex; align-items: center; justify-content: center;
    }

.lwpt-search-modal--p-center .lwpt-search-modal__panel {
        margin: 0 auto; max-height: 84vh; display: flex; flex-direction: column;
    }

.lwpt-search-modal--p-center .lwpt-search-modal__body { flex: 1 1 auto; }

.lwpt-search-modal.is-open .lwpt-search-modal__panel { transform: translateY(0) scale(1); opacity: 1; }

.lwpt-search-modal__form {
        display: grid; grid-template-columns: auto 1fr auto auto; align-items: center; gap: 10px;
        padding: 14px 16px; border-bottom: 1px solid var(--lwpt-color-border, #e2e8f0);
    }

.lwpt-search-modal__icon { color: var(--lwpt-color-muted, #64748b); display: inline-flex; }

.lwpt-search-modal__input {
        border: 0; outline: none; background: transparent;
        font-family: inherit; font-size: 18px; color: var(--lwpt-color-text, #0f172a);
        -moz-appearance: textfield;
             appearance: textfield;
        -webkit-appearance: none;
    }

/* Suppress the browser's native clear ("X") button on <input type="search">
       so we don't render two clear buttons side-by-side. */

.lwpt-search-modal__input::-webkit-search-cancel-button,
    .lwpt-search-modal__input::-webkit-search-decoration,
    .lwpt-search-modal__input::-webkit-search-results-button,
    .lwpt-search-modal__input::-webkit-search-results-decoration {
        -webkit-appearance: none; appearance: none; display: none;
    }

.lwpt-search-modal__input::-ms-clear,
    .lwpt-search-modal__input::-ms-reveal { display: none; width: 0; height: 0; }

.lwpt-search-modal__clear {
        -webkit-appearance: none;
           -moz-appearance: none;
                appearance: none; background: color-mix(in srgb, var(--lwpt-color-text, #0f172a) 6%, transparent);
        border: 0; width: 28px; height: 28px; border-radius: 999px; cursor: pointer; color: var(--lwpt-color-muted);
        display: inline-flex; align-items: center; justify-content: center;
    }

.lwpt-search-modal__clear:hover { background: color-mix(in srgb, var(--lwpt-color-text) 12%, transparent); }

.lwpt-search-modal__close {
        -webkit-appearance: none;
           -moz-appearance: none;
                appearance: none; background: transparent; border: 0; color: var(--lwpt-color-muted); cursor: pointer; padding: 6px;
    }

.lwpt-search-modal__kbd {
        font-family: ui-monospace, monospace; font-size: 11px; padding: 3px 6px; border-radius: 4px;
        background: color-mix(in srgb, var(--lwpt-color-text) 8%, transparent);
        border: 1px solid var(--lwpt-color-border, #e2e8f0);
    }

/* Category filter chips — horizontally scrollable strip between the
       search field and the results body. The strip hides its scrollbar
       but keeps native swipe/scroll on touch devices. */

.lwpt-search-modal__chips {
        display: flex;
        flex-wrap: nowrap;
        gap: 8px;
        padding: 12px 20px 14px;
        overflow-x: auto;
        overflow-y: hidden;
        scrollbar-width: none;
        -ms-overflow-style: none;
        border-bottom: 1px solid var(--lwpt-color-border, #e5e7eb);
        scroll-snap-type: x proximity;
        -webkit-overflow-scrolling: touch;
        position: relative;
    }

.lwpt-search-modal__chips::-webkit-scrollbar { display: none; }

/* Edge fade hints — show only when the strip can scroll. */

.lwpt-search-modal__chips::before,
    .lwpt-search-modal__chips::after {
        content: "";
        position: sticky;
        top: 0;
        width: 24px;
        height: 100%;
        flex-shrink: 0;
        pointer-events: none;
    }

.lwpt-search-modal__chips::before {
        left: 0;
        margin-right: -16px;
        background: linear-gradient(90deg, var(--lwpt-color-card-bg, #fff), transparent);
    }

.lwpt-search-modal__chips::after {
        right: 0;
        margin-left: -16px;
        background: linear-gradient(270deg, var(--lwpt-color-card-bg, #fff), transparent);
    }

.lwpt-search-chip {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        flex-shrink: 0;
        padding: 6px 12px;
        background: var(--lwpt-color-bg-alt, #f1f5f9);
        color: var(--lwpt-color-text, #0f172a);
        border: 1px solid transparent;
        border-radius: 999px;
        font-size: 12.5px;
        font-weight: 600;
        line-height: 1.4;
        cursor: pointer;
        transition: background .12s ease, color .12s ease, border-color .12s ease, transform .12s ease;
        scroll-snap-align: start;
        white-space: nowrap;
    }

.lwpt-search-chip:hover {
        background: var(--lwpt-color-card-bg, #fff);
        border-color: var(--lwpt-color-border, #e2e8f0);
    }

.lwpt-search-chip:focus-visible {
        outline: 2px solid var(--lwpt-color-primary, #6366f1);
        outline-offset: 2px;
    }

.lwpt-search-chip.is-active {
        background: var(--lwpt-color-primary, #6366f1);
        color: #fff;
        border-color: var(--lwpt-color-primary, #6366f1);
        box-shadow: 0 4px 12px -4px var(--lwpt-color-primary, rgba(99,102,241,.5));
    }

/* Chip with zero matches in the current query — dimmed but still
       clickable so a user can recover by switching back. */

.lwpt-search-chip.is-empty {
        opacity: .4;
        text-decoration: line-through;
        text-decoration-color: var(--lwpt-color-muted, #94a3b8);
        text-decoration-thickness: 1px;
    }

.lwpt-search-chip.is-empty:hover {
        opacity: .65;
    }

.lwpt-search-chip.is-empty.is-active {
        opacity: 1;
        text-decoration: none;
    }

.lwpt-search-chip__count {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 18px;
        height: 18px;
        padding: 0 5px;
        font-size: 10.5px;
        font-weight: 700;
        background: rgba(15, 23, 42, .08);
        border-radius: 999px;
    }

.lwpt-search-chip.is-active .lwpt-search-chip__count {
        background: rgba(255, 255, 255, .25);
        color: #fff;
    }

.lwpt-search-modal__body { max-height: 60vh; overflow-y: auto; padding: 8px 0; }

.lwpt-search-modal__state { padding: 16px 20px; }

.lwpt-search-modal__state--empty    { text-align: left; }

.lwpt-search-modal__state--loading,
    .lwpt-search-modal__state--none     { text-align: center; color: var(--lwpt-color-muted, #64748b); padding: 40px 20px; }

.lwpt-search-modal__hint   { color: var(--lwpt-color-muted, #64748b); font-size: 13px; margin: 0; }

.lwpt-search-modal__recent h3 {
        font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em;
        color: var(--lwpt-color-muted, #64748b); margin: 16px 0 6px;
    }

.lwpt-search-modal__recent ul { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 6px; }

.lwpt-search-modal__recent button {
        -webkit-appearance: none;
           -moz-appearance: none;
                appearance: none; border: 1px solid var(--lwpt-color-border, #e2e8f0);
        background: var(--lwpt-color-bg-alt, #f8fafc); color: var(--lwpt-color-text);
        border-radius: 999px; padding: 4px 12px; font-size: 13px; cursor: pointer;
    }

.lwpt-search-modal__recent button:hover { border-color: var(--lwpt-color-primary, #4f46e5); color: var(--lwpt-color-primary); }

.lwpt-search-modal__spinner {
        width: 28px; height: 28px; border-radius: 50%;
        border: 3px solid var(--lwpt-color-border, #e2e8f0);
        border-top-color: var(--lwpt-color-primary, #4f46e5);
        margin: 0 auto 12px; animation: lwpt-spin 0.8s linear infinite;
    }

@keyframes lwpt-spin { to { transform: rotate(360deg); } }

.lwpt-search-modal__count { font-size: 12px; color: var(--lwpt-color-muted); margin: 0 20px 6px; text-transform: uppercase; letter-spacing: 0.06em; }

.lwpt-search-modal__results { list-style: none; margin: 0; padding: 0; }

.lwpt-search-modal__results li a {
        display: grid; grid-template-columns: auto 1fr auto; gap: 14px; align-items: center;
        padding: 12px 20px; color: inherit; text-decoration: none;
        border-left: 3px solid transparent; transition: background 0.15s, border-color 0.15s;
    }

.lwpt-search-modal__results li a.is-active,
    .lwpt-search-modal__results li a:hover {
        background: color-mix(in srgb, var(--lwpt-color-primary, #4f46e5) 5%, transparent);
        border-left-color: var(--lwpt-color-primary, #4f46e5);
    }

.lwpt-search-result__thumb { width: 56px; height: 56px; border-radius: 8px; overflow: hidden; background: var(--lwpt-color-bg-alt, #f8fafc); flex-shrink: 0; }

.lwpt-search-result__thumb img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; display: block; }

.lwpt-search-result__body  { display: flex; flex-direction: column; gap: 2px; min-width: 0; }

.lwpt-search-result__meta  { display: flex; gap: 8px; align-items: center; font-size: 11px; color: var(--lwpt-color-muted, #64748b); text-transform: uppercase; letter-spacing: 0.06em; }

.lwpt-search-result__type  { color: var(--lwpt-color-primary, #4f46e5); font-weight: 700; }

.lwpt-search-result__title { font-weight: 700; font-size: 15px; color: var(--lwpt-color-heading, var(--lwpt-color-text)); line-height: 1.35; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.lwpt-search-result__excerpt { font-size: 13px; color: var(--lwpt-color-muted, #64748b); overflow: hidden; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; }

.lwpt-search-result__arrow { color: var(--lwpt-color-muted); font-size: 18px; opacity: 0; transition: opacity 0.15s, transform 0.15s; }

.lwpt-search-modal__results li a.is-active .lwpt-search-result__arrow,
    .lwpt-search-modal__results li a:hover     .lwpt-search-result__arrow { opacity: 1; transform: translateX(2px); color: var(--lwpt-color-primary); }

.lwpt-search-modal__results mark { background: color-mix(in srgb, var(--lwpt-color-primary) 20%, transparent); color: inherit; padding: 0 2px; border-radius: 3px; }

.lwpt-search-modal__all {
        display: block; text-align: center; padding: 12px; color: var(--lwpt-color-primary);
        text-decoration: none; font-weight: 600; font-size: 14px;
        border-top: 1px solid var(--lwpt-color-border, #e2e8f0);
    }

.lwpt-search-modal__all:hover { background: var(--lwpt-color-bg-alt, #f8fafc); }

.lwpt-search-modal__footer {
        display: flex; gap: 16px; padding: 10px 20px; font-size: 11px; color: var(--lwpt-color-muted);
        border-top: 1px solid var(--lwpt-color-border, #e2e8f0);
        background: var(--lwpt-color-bg-alt, #f8fafc);
    }

.lwpt-search-modal__legend { display: inline-flex; gap: 4px; align-items: center; }

.lwpt-search-modal__footer kbd {
        font-family: ui-monospace, monospace; font-size: 10px; padding: 2px 5px; border-radius: 3px;
        background: var(--lwpt-color-bg, #fff); border: 1px solid var(--lwpt-color-border, #e2e8f0);
    }

body.lwpt-has-search { overflow: hidden; }

@media (max-width: 640px) {
        .lwpt-search-modal__panel { margin: 0; max-width: none; height: 100%; border-radius: 0; }
        .lwpt-search-modal__body { max-height: calc(100vh - 120px); }
    }

.visible {
  visibility: visible;
}

.invisible {
  visibility: hidden;
}

.collapse {
  visibility: collapse;
}

.static {
  position: static;
}

.fixed {
  position: fixed;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.sticky {
  position: sticky;
}

.inset-0 {
  inset: 0px;
}

.bottom-0 {
  bottom: 0px;
}

.bottom-6 {
  bottom: 1.5rem;
}

.left-0 {
  left: 0px;
}

.left-2 {
  left: 0.5rem;
}

.left-3 {
  left: 0.75rem;
}

.right-0 {
  right: 0px;
}

.right-6 {
  right: 1.5rem;
}

.top-0 {
  top: 0px;
}

.top-1\/2 {
  top: 50%;
}

.top-2 {
  top: 0.5rem;
}

.top-3 {
  top: 0.75rem;
}

.top-32 {
  top: 8rem;
}

.isolate {
  isolation: isolate;
}

.z-30 {
  z-index: 30;
}

.z-40 {
  z-index: 40;
}

.m-0 {
  margin: 0px;
}

.-mx-4 {
  margin-left: -1rem;
  margin-right: -1rem;
}

.mx-1 {
  margin-left: 0.25rem;
  margin-right: 0.25rem;
}

.my-5 {
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
}

.my-8 {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.mb-10 {
  margin-bottom: 2.5rem;
}

.mb-2 {
  margin-bottom: 0.5rem;
}

.mb-3 {
  margin-bottom: 0.75rem;
}

.mb-4 {
  margin-bottom: 1rem;
}

.mb-8 {
  margin-bottom: 2rem;
}

.ml-2 {
  margin-left: 0.5rem;
}

.mt-1 {
  margin-top: 0.25rem;
}

.mt-10 {
  margin-top: 2.5rem;
}

.mt-12 {
  margin-top: 3rem;
}

.mt-2 {
  margin-top: 0.5rem;
}

.mt-8 {
  margin-top: 2rem;
}

.mt-auto {
  margin-top: auto;
}

.block {
  display: block;
}

.inline-block {
  display: inline-block;
}

.inline {
  display: inline;
}

.flex {
  display: flex;
}

.inline-flex {
  display: inline-flex;
}

.table {
  display: table;
}

.grid {
  display: grid;
}

.contents {
  display: contents;
}

.hidden {
  display: none;
}

.h-10 {
  height: 2.5rem;
}

.h-11 {
  height: 2.75rem;
}

.h-16 {
  height: 4rem;
}

.h-20 {
  height: 5rem;
}

.h-52 {
  height: 13rem;
}

.h-8 {
  height: 2rem;
}

.h-9 {
  height: 2.25rem;
}

.h-\[40vh\] {
  height: 40vh;
}

.h-auto {
  height: auto;
}

.max-h-10 {
  max-height: 2.5rem;
}

.max-h-\[70vh\] {
  max-height: 70vh;
}

.min-h-\[180px\] {
  min-height: 180px;
}

.w-10 {
  width: 2.5rem;
}

.w-11 {
  width: 2.75rem;
}

.w-12 {
  width: 3rem;
}

.w-16 {
  width: 4rem;
}

.w-20 {
  width: 5rem;
}

.w-64 {
  width: 16rem;
}

.w-8 {
  width: 2rem;
}

.w-9 {
  width: 2.25rem;
}

.w-full {
  width: 100%;
}

.min-w-10 {
  min-width: 2.5rem;
}

.max-w-md {
  max-width: 28rem;
}

.max-w-prose {
  max-width: var(--lwpt-prose-width, 760px);
}

.flex-shrink {
  flex-shrink: 1;
}

.shrink {
  flex-shrink: 1;
}

.grow {
  flex-grow: 1;
}

.border-collapse {
  border-collapse: collapse;
}

.-translate-y-1\/2 {
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.resize {
  resize: both;
}

.list-none {
  list-style-type: none;
}

.flex-col {
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.items-start {
  align-items: flex-start;
}

.items-end {
  align-items: flex-end;
}

.items-center {
  align-items: center;
}

.items-stretch {
  align-items: stretch;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.gap-1 {
  gap: 0.25rem;
}

.gap-1\.5 {
  gap: 0.375rem;
}

.gap-2 {
  gap: 0.5rem;
}

.gap-3 {
  gap: 0.75rem;
}

.gap-4 {
  gap: 1rem;
}

.gap-6 {
  gap: 1.5rem;
}

.gap-x-3 {
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
}

.gap-x-8 {
  -moz-column-gap: 2rem;
       column-gap: 2rem;
}

.gap-y-1 {
  row-gap: 0.25rem;
}

.overflow-auto {
  overflow: auto;
}

.overflow-hidden {
  overflow: hidden;
}

.rounded {
  border-radius: 0.25rem;
}

.rounded-card {
  border-radius: 14px;
}

.rounded-full {
  border-radius: 9999px;
}

.rounded-lg {
  border-radius: 0.5rem;
}

.rounded-none {
  border-radius: 0px;
}

.border {
  border-width: 1px;
}

.border-0 {
  border-width: 0px;
}

.border-y {
  border-top-width: 1px;
  border-bottom-width: 1px;
}

.border-b {
  border-bottom-width: 1px;
}

.border-l-4 {
  border-left-width: 4px;
}

.border-t {
  border-top-width: 1px;
}

.border-t-2 {
  border-top-width: 2px;
}

.border-border {
  border-color: var(--lwpt-color-border, #e2e8f0);
}

.bg-ink {
  background-color: var(--lwpt-color-text, #0f172a);
}

.bg-primary {
  background-color: var(--lwpt-color-primary, #4f46e5);
}

.bg-surface {
  background-color: var(--lwpt-color-bg, #ffffff);
}

.bg-surface-2 {
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
}

.bg-transparent {
  background-color: transparent;
}

.bg-gradient-to-br {
  background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
}

.from-surface-2 {
  --tw-gradient-from: var(--lwpt-color-bg-alt, #f8fafc) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.to-surface {
  --tw-gradient-to: var(--lwpt-color-bg, #ffffff) var(--tw-gradient-to-position);
}

.object-cover {
  -o-object-fit: cover;
     object-fit: cover;
}

.p-0 {
  padding: 0px;
}

.p-4 {
  padding: 1rem;
}

.p-5 {
  padding: 1.25rem;
}

.p-6 {
  padding: 1.5rem;
}

.px-1 {
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}

.px-2 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.px-3 {
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.px-5 {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

.px-6 {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.py-0 {
  padding-top: 0px;
  padding-bottom: 0px;
}

.py-0\.5 {
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
}

.py-1 {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

.py-10 {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.py-14 {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}

.py-2 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.py-2\.5 {
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}

.py-20 {
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.py-24 {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.py-4 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.pb-10 {
  padding-bottom: 2.5rem;
}

.pb-4 {
  padding-bottom: 1rem;
}

.pl-4 {
  padding-left: 1rem;
}

.pl-5 {
  padding-left: 1.25rem;
}

.pt-2 {
  padding-top: 0.5rem;
}

.pt-4 {
  padding-top: 1rem;
}

.pt-6 {
  padding-top: 1.5rem;
}

.text-center {
  text-align: center;
}

.font-body {
  font-family: var(--lwpt-font-body, Inter), system-ui, sans-serif;
}

.font-heading {
  font-family: var(--lwpt-font-heading, Inter), system-ui, sans-serif;
}

.text-7xl {
  font-size: 4.5rem;
  line-height: 1;
}

.text-\[0\.9em\] {
  font-size: 0.9em;
}

.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}

.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}

.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}

.font-black {
  font-weight: 900;
}

.font-bold {
  font-weight: 700;
}

.font-extrabold {
  font-weight: 800;
}

.font-medium {
  font-weight: 500;
}

.font-normal {
  font-weight: 400;
}

.font-semibold {
  font-weight: 600;
}

.uppercase {
  text-transform: uppercase;
}

.capitalize {
  text-transform: capitalize;
}

.italic {
  font-style: italic;
}

.tracking-tight {
  letter-spacing: -0.025em;
}

.tracking-wider {
  letter-spacing: 0.05em;
}

.tracking-widest {
  letter-spacing: 0.1em;
}

.text-ink {
  color: var(--lwpt-color-text, #0f172a);
}

.text-muted {
  color: var(--lwpt-color-muted, #64748b);
}

.text-primary {
  color: var(--lwpt-color-primary, #4f46e5);
}

.text-surface {
  color: var(--lwpt-color-bg, #ffffff);
}

.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.underline {
  text-decoration-line: underline;
}

.no-underline {
  text-decoration-line: none;
}

.antialiased {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.opacity-0 {
  opacity: 0;
}

.opacity-100 {
  opacity: 1;
}

.opacity-80 {
  opacity: 0.8;
}

.shadow {
  --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-lg {
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-md {
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.outline {
  outline-style: solid;
}

.ring {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.blur {
  --tw-blur: blur(8px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow {
  --tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / 0.1)) drop-shadow(0 1px 1px rgb(0 0 0 / 0.06));
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.sepia {
  --tw-sepia: sepia(100%);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.backdrop-filter {
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.ease-in-out {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ─── Base ───────────────────────────────────────────────────────────── */

/* ─── Components ─────────────────────────────────────────────────────── */

/* ════════════════════════════════════════════════════════════════════════════
   v1.1 — Expanded layout variants (container, sidebar, title-area, cards,
   image-hover, breadcrumbs separator, social styles/sizes, related layouts).
   ════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════════
   v1.2 — Headers (modern + stacked + announcement bar), responsive drawer,
   responsive polish across all breakpoints.
   ════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════════
   v1.3 — Wire every base style to Customizer CSS variables so colors,
   typography, and spacing settings (including preset overrides) take effect.
   ════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════════
   v1.4 — Per-single-post-section design overrides. Each rule uses
   var(--lwpt-s-*, fallback) so it silently inherits global tokens unless
   the admin has set a per-section value in Customizer.
   ════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════════
   v1.5 — Header search (inline field + live-search modal)
   ════════════════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════════
   FACT CHECK TRUST CARD — horizontal with avatar-only stacks +
   rich hover/focus popovers per person.
   ══════════════════════════════════════════════════════════════════ */

.lwpt-factcheck {
    --fc-primary:    #6366f1;
    --fc-primary-2:  #8b5cf6;
    --fc-primary-3:  #ec4899;
    --fc-text:       var(--lwpt-fc-text, #0f172a);
    --fc-muted:      var(--lwpt-fc-label, #64748b);
    --fc-border:     var(--lwpt-fc-border-color, rgba(99, 102, 241, .14));
    --fc-success:    #10b981;
    --fc-success-2:  #059669;
    --fc-success-bg: #ecfdf5;

    margin-block: var(--lwpt-fc-margin-y, 24px);
    border-radius: var(--lwpt-fc-radius, 18px);
    background:
        radial-gradient(800px circle at 0% 0%, rgba(99, 102, 241, .08), transparent 45%),
        radial-gradient(600px circle at 100% 100%, rgba(236, 72, 153, .06), transparent 45%),
        radial-gradient(900px circle at 50% 0%, rgba(139, 92, 246, .05), transparent 60%),
        linear-gradient(180deg, rgba(255, 255, 255, .92) 0%, rgba(250, 251, 255, .96) 100%);
    backdrop-filter: blur(8px) saturate(140%);
    -webkit-backdrop-filter: blur(8px) saturate(140%);
    border: var(--lwpt-fc-border-width, 1px) solid var(--fc-border);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .8),
        0 1px 2px rgba(15, 23, 42, .04),
        0 12px 40px -8px rgba(99, 102, 241, .12),
        0 32px 80px -32px rgba(139, 92, 246, .08);
    position: relative;
    overflow: visible;             /* popovers escape the box */
    isolation: isolate;
}

/* Subtle top-edge accent — a thin gradient line that lifts the card. */

.lwpt-factcheck::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 1px;
    border-radius: inherit;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(99, 102, 241, .35) 20%,
        rgba(139, 92, 246, .45) 50%,
        rgba(236, 72, 153, .35) 80%,
        transparent 100%);
    pointer-events: none;
    opacity: .8;
}

/* Solid background override — applied as the LAST background so it
   wins over the gradient defaults when the user picks a custom color. */

.lwpt-factcheck[style*="--lwpt-fc-bg"] {
    background: var(--lwpt-fc-bg);
}

/* Shadow variants */

.lwpt-factcheck--shadow-none { box-shadow: none; }

.lwpt-factcheck--shadow-soft {
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04),
                0 8px 28px rgba(99, 102, 241, .06);
}

.lwpt-factcheck--shadow-hard {
    box-shadow: 0 6px 20px rgba(15, 23, 42, .12),
                0 18px 48px rgba(15, 23, 42, .08);
}

/* Layout variants */

.lwpt-factcheck--layout-stacked .lwpt-factcheck__row {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
}

.lwpt-factcheck--layout-stacked .lwpt-factcheck__stacks {
    margin-left: 0;
    justify-content: flex-start;
}

.lwpt-factcheck--layout-compact .lwpt-factcheck__row {
    padding-block: calc(var(--lwpt-fc-pad-y, 14px) - 4px);
    gap: 14px;
}

.lwpt-factcheck--layout-compact .lwpt-factcheck__lead-sub { display: none; }

.lwpt-factcheck--layout-compact .lwpt-factcheck__stack { padding-left: 10px; }

.lwpt-factcheck--layout-pill {
    border-radius: 999px !important;
}

.lwpt-factcheck--layout-pill .lwpt-factcheck__row {
    padding-block: 10px;
}

/* Alignment variants — control where the stacks sit */

.lwpt-factcheck--align-left   .lwpt-factcheck__stacks { margin-left: 0; }

.lwpt-factcheck--align-center .lwpt-factcheck__stacks { margin-inline: auto; }

.lwpt-factcheck--align-right  .lwpt-factcheck__stacks { margin-left: auto; }

.lwpt-factcheck--align-space-between .lwpt-factcheck__row { justify-content: space-between; }

/* Toggleable parts */

.lwpt-factcheck--no-badge .lwpt-factcheck__lead { display: none; }

.lwpt-factcheck--no-labels .lwpt-factcheck__stack-label { display: none; }

.lwpt-factcheck--upper-labels .lwpt-factcheck__stack-label {
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.lwpt-factcheck__row {
    display: flex;
    align-items: center;
    gap: 28px;
    padding: var(--lwpt-fc-pad-y, 18px) var(--lwpt-fc-pad-x, 26px);
    flex-wrap: wrap;
}

/* ── Lead cluster: gradient shield + verified label + reviewed time ── */

.lwpt-factcheck__lead {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-shrink: 0;
    padding-right: 24px;
    border-right: 1px solid;
    -o-border-image: linear-gradient(
        180deg,
        transparent 10%,
        rgba(99, 102, 241, .18) 50%,
        transparent 90%
    ) 1;
       border-image: linear-gradient(
        180deg,
        transparent 10%,
        rgba(99, 102, 241, .18) 50%,
        transparent 90%
    ) 1;
}

.lwpt-factcheck__badge {
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background:
        radial-gradient(circle at 30% 30%, rgba(255, 255, 255, .9), rgba(255, 255, 255, .6) 60%),
        linear-gradient(135deg, rgba(99, 102, 241, .12), rgba(236, 72, 153, .12));
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, .9),
        inset 0 -2px 4px rgba(99, 102, 241, .12),
        0 1px 0 rgba(15, 23, 42, .04),
        0 8px 24px rgba(99, 102, 241, .25),
        0 0 0 6px rgba(99, 102, 241, .06);
    flex-shrink: 0;
    position: relative;
    animation: lwpt-fc-badge-pulse 4s ease-in-out infinite;
}

/* Soft pulse ring — gives the badge a subtle living quality. */

.lwpt-factcheck__badge::before {
    content: "";
    position: absolute;
    inset: -6px;
    border-radius: 50%;
    background: conic-gradient(from 0deg,
        rgba(99, 102, 241, .4),
        rgba(139, 92, 246, .4),
        rgba(236, 72, 153, .4),
        rgba(99, 102, 241, .4));
    z-index: -1;
    opacity: .35;
    filter: blur(6px);
    animation: lwpt-fc-rotate 8s linear infinite;
}

@keyframes lwpt-fc-badge-pulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.03); }
}

@keyframes lwpt-fc-rotate {
    to { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
    .lwpt-factcheck__badge,
    .lwpt-factcheck__badge::before { animation: none; }
}

.lwpt-factcheck__badge svg {
    display: block;
    width: 30px;
    height: 30px;
    filter: drop-shadow(0 1px 2px rgba(99, 102, 241, .35));
}

.lwpt-factcheck__lead-text {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
    gap: 3px;
}

.lwpt-factcheck__lead-title {
    font-size: 15px;
    font-weight: 800;
    color: var(--fc-text);
    letter-spacing: -0.015em;
    background: linear-gradient(120deg, var(--fc-text) 0%, #1e293b 100%);
    -webkit-background-clip: text;
    background-clip: text;
}

.lwpt-factcheck__lead-sub {
    font-size: 12px;
    color: var(--fc-muted);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* Tiny "live" dot that indicates a recent review. */

.lwpt-factcheck__lead-sub::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--fc-success);
    box-shadow: 0 0 0 2px rgba(16, 185, 129, .18);
    animation: lwpt-fc-blink 2.4s ease-in-out infinite;
}

@keyframes lwpt-fc-blink {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: .4; transform: scale(.85); }
}

@media (prefers-reduced-motion: reduce) {
    .lwpt-factcheck__lead-sub::before { animation: none; }
}

.lwpt-factcheck__lead-sub time { font-weight: 700; color: var(--fc-text); }

/* ── Stack groups (Researched / Fact-checked / Contributors) ───── */

.lwpt-factcheck__stacks {
    display: flex;
    align-items: center;
    gap: 28px;
    margin-left: auto;
    flex-wrap: wrap;
}

.lwpt-factcheck__stack {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-left: 24px;
    position: relative;
}

/* Gradient vertical separator — fades softly at top and bottom for an
   editorial, magazine-y feel. */

.lwpt-factcheck__stack::before {
    content: "";
    position: absolute;
    left: 0;
    top: 6px;
    bottom: 6px;
    width: 1px;
    background: linear-gradient(180deg,
        transparent 0%,
        rgba(99, 102, 241, .22) 25%,
        rgba(139, 92, 246, .22) 75%,
        transparent 100%);
}

.lwpt-factcheck__stack:first-child::before,
.lwpt-factcheck__stack:first-child { padding-left: 0; }

.lwpt-factcheck__stack:first-child::before { display: none; }

.lwpt-factcheck__stack-label {
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--fc-muted);
    white-space: nowrap;
    position: relative;
}

/* Color-coded role accents — a tiny dot before the label in the role's hue. */

.lwpt-factcheck__stack[data-role="researched"]   .lwpt-factcheck__stack-label::before,
.lwpt-factcheck__stack[data-role="factchecked"]  .lwpt-factcheck__stack-label::before,
.lwpt-factcheck__stack[data-role="contributors"] .lwpt-factcheck__stack-label::before {
    content: "";
    display: inline-block;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    margin-right: 6px;
    transform: translateY(-1px);
    vertical-align: middle;
}

.lwpt-factcheck__stack[data-role="researched"]   .lwpt-factcheck__stack-label::before { background: linear-gradient(135deg, #6366f1, #8b5cf6); }

.lwpt-factcheck__stack[data-role="factchecked"]  .lwpt-factcheck__stack-label::before { background: linear-gradient(135deg, #10b981, #059669); }

.lwpt-factcheck__stack[data-role="contributors"] .lwpt-factcheck__stack-label::before { background: linear-gradient(135deg, #ec4899, #f43f5e); }

/* ── Avatar stack — overlapping circles ───────────────────────── */

.lwpt-factcheck__avatars {
    list-style: none;
    margin: 0;
    padding: 0;
    display: inline-flex;
}

.lwpt-factcheck__avatar-wrap {
    list-style: none;
    margin: 0;
    padding: 0;
    /* Negative margin produces the overlapping-circles effect; first
       child resets so the leftmost avatar doesn't get clipped. */
    margin-left: calc(-1 * var(--lwpt-fc-avatar-overlap, 10px));
    position: relative;
    z-index: calc( 10 - var(--lwpt-fc-i, 0) );
}

.lwpt-factcheck__avatar-wrap:first-child { margin-left: 0; }

.lwpt-factcheck__avatar-link {
    position: relative;
    display: inline-block;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    text-decoration: none;
    line-height: 0;
    transition: transform .25s cubic-bezier(.2, .9, .3, 1.4);
    outline: none;
}

/* Soft gradient halo — appears on hover for a premium feel. */

.lwpt-factcheck__avatar-link::before {
    content: "";
    position: absolute;
    inset: -3px;
    border-radius: 50%;
    background: conic-gradient(from 90deg,
        var(--fc-primary),
        var(--fc-primary-2),
        var(--fc-primary-3),
        var(--fc-primary));
    opacity: 0;
    transition: opacity .2s ease;
    z-index: -1;
}

.lwpt-factcheck__avatar-link:hover,
.lwpt-factcheck__avatar-link:focus-visible {
    z-index: 50;                   /* lift the active avatar above siblings */
    transform: translateY(-3px) scale(1.08);
}

.lwpt-factcheck__avatar-link:hover::before,
.lwpt-factcheck__avatar-link:focus-visible::before {
    opacity: 1;
}

.lwpt-factcheck__avatar-link:focus-visible {
    box-shadow: 0 0 0 3px rgba(99, 102, 241, .35);
}

.lwpt-factcheck__avatar-img {
    width: var(--lwpt-fc-avatar-size, 38px);
    height: var(--lwpt-fc-avatar-size, 38px);
    border-radius: 50%;
    -o-object-fit: cover;
       object-fit: cover;
    background: #e2e8f0;
    border: 2.5px solid #fff;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, .14),
        0 4px 10px rgba(15, 23, 42, .08);
    transition: box-shadow .2s ease;
}

.lwpt-factcheck__avatar-link:hover .lwpt-factcheck__avatar-img {
    box-shadow:
        0 2px 4px rgba(99, 102, 241, .18),
        0 12px 28px rgba(99, 102, 241, .25);
}

.lwpt-factcheck__avatar-check {
    position: absolute;
    right: -3px;
    bottom: -3px;
    width: 18px;
    height: 18px;
    background: linear-gradient(135deg, var(--fc-success), var(--fc-success-2));
    color: #fff;
    border: 2.5px solid #fff;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow:
        0 1px 2px rgba(16, 185, 129, .25),
        0 4px 10px rgba(16, 185, 129, .35);
    transition: transform .2s ease;
}

.lwpt-factcheck__avatar-link:hover .lwpt-factcheck__avatar-check {
    transform: scale(1.15);
}

/* ── Hover/focus popover ──────────────────────────────────────────
   Lightweight contact card design: avatar on the left, name + role
   stacked on the right, divider, then a "View profile →" CTA. The
   popover uses a CSS-pseudo arrow so the bubble points at the avatar
   it describes and stays attached visually. */

.lwpt-factcheck__pop {
    position: absolute;
    bottom: calc(100% + 14px);
    left: 50%;
    transform: translateX(-50%) translateY(4px) scale(.96);
    transform-origin: bottom center;
    width: 280px;
    padding: 16px 18px 12px;
    background: #fff;
    border: 0;
    border-radius: 14px;
    box-shadow:
        0 1px 3px rgba(15, 23, 42, .08),
        0 12px 32px rgba(15, 23, 42, .14),
        0 32px 64px rgba(15, 23, 42, .08);
    color: var(--fc-text);
    text-align: left;
    line-height: 1.4;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .18s ease, transform .2s cubic-bezier(.2, .9, .3, 1.2), visibility .18s;
    z-index: 100;
    white-space: normal;
}

/* Triangular pointer that visually anchors the bubble to the avatar.
   Two stacked elements: a slightly larger one to mimic a soft shadow
   and a clean white tip on top. */

.lwpt-factcheck__pop::before,
.lwpt-factcheck__pop::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    width: 14px;
    height: 14px;
    background: #fff;
    transform: translate(-50%, -50%) rotate(45deg);
}

.lwpt-factcheck__pop::before {
    box-shadow: 0 6px 14px rgba(15, 23, 42, .08);
    z-index: -1;
}

.lwpt-factcheck__avatar-link:hover .lwpt-factcheck__pop,
.lwpt-factcheck__avatar-link:focus-visible .lwpt-factcheck__pop {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0) scale(1);
}

.lwpt-factcheck__pop-head {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid #eef2f7;
    margin-bottom: 12px;
}

.lwpt-factcheck__pop-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    -o-object-fit: cover;
       object-fit: cover;
    background: #e2e8f0;
    flex-shrink: 0;
    box-shadow: 0 2px 6px rgba(15, 23, 42, .12);
}

.lwpt-factcheck__pop-meta {
    display: flex;
    flex-direction: column;
    min-width: 0;
    gap: 4px;
}

.lwpt-factcheck__pop-name {
    font-size: 16px;
    font-weight: 800;
    color: #0f172a;
    letter-spacing: -.01em;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.lwpt-factcheck__pop-role {
    font-size: 11px;
    font-weight: 700;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    line-height: 1.3;
}

.lwpt-factcheck__pop-bio {
    display: block;
    font-size: 13px;
    color: #475569;
    margin: 0 0 10px;
    line-height: 1.5;
}

.lwpt-factcheck__pop-cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 700;
    color: var(--fc-primary, #4f46e5);
    text-decoration: none;
    transition: gap .15s ease, color .15s ease;
}

.lwpt-factcheck__avatar-link:hover .lwpt-factcheck__pop-cta { gap: 10px; }

/* ── Responsive ──────────────────────────────────────────────── */

@media (max-width: 720px) {
    .lwpt-factcheck { border-radius: 14px; }
    .lwpt-factcheck__row {
        gap: 16px;
        padding: 16px 18px;
    }
    .lwpt-factcheck__lead {
        padding-right: 0;
        border-right: 0;
        padding-bottom: 14px;
        width: 100%;
        border-bottom: 1px solid;
        -o-border-image: linear-gradient(
            90deg,
            transparent 0%,
            rgba(99, 102, 241, .18) 50%,
            transparent 100%
        ) 1;
           border-image: linear-gradient(
            90deg,
            transparent 0%,
            rgba(99, 102, 241, .18) 50%,
            transparent 100%
        ) 1;
    }
    .lwpt-factcheck__badge { width: 42px; height: 42px; }
    .lwpt-factcheck__badge svg { width: 26px; height: 26px; }
    .lwpt-factcheck__stacks {
        margin-left: 0;
        gap: 16px;
        width: 100%;
    }
    .lwpt-factcheck__stack { padding-left: 14px; }
    .lwpt-factcheck__stack-label { display: none; }
    .lwpt-factcheck__pop { width: 240px; }
}

/* ── Dark-background context — when the fact-check card sits on top of
      a dark hero (e.g. behind-title featured image), boost contrast.
      Skip when the user has set a custom card background so the inline
      --lwpt-fc-bg value wins instead of being clobbered. */

.lwpt-title-area--bg-image + .lwpt-factcheck:not([style*="--lwpt-fc-bg"]),
.lwpt-title-area--bg-gradient + .lwpt-factcheck:not([style*="--lwpt-fc-bg"]),
.lwpt-featured--behind-title + .lwpt-container .lwpt-factcheck:not([style*="--lwpt-fc-bg"]) {
    background:
        radial-gradient(800px circle at 0% 0%, rgba(99, 102, 241, .14), transparent 45%),
        radial-gradient(600px circle at 100% 100%, rgba(236, 72, 153, .10), transparent 45%),
        linear-gradient(180deg, rgba(255, 255, 255, .98) 0%, rgba(255, 255, 255, 1) 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 1),
        0 2px 4px rgba(15, 23, 42, .08),
        0 16px 48px -8px rgba(15, 23, 42, .25),
        0 32px 80px -32px rgba(15, 23, 42, .35);
}

@media (max-width: 480px) {
    .lwpt-factcheck__pop {
        width: 240px;
        left: auto;
        right: -8px;
        transform: translateY(4px) scale(.96);
    }
    .lwpt-factcheck__pop::before,
    .lwpt-factcheck__pop::after {
        left: auto;
        right: 22px;
        transform: translate(0, -50%) rotate(45deg);
    }
    .lwpt-factcheck__avatar-link:hover .lwpt-factcheck__pop,
    .lwpt-factcheck__avatar-link:focus-visible .lwpt-factcheck__pop {
        transform: translateY(0) scale(1);
    }
}

@media (prefers-reduced-motion: reduce) {
    .lwpt-factcheck__avatar-link,
    .lwpt-factcheck__pop {
        transition: none;
    }
}

/* ══════════════════════════════════════════════════════════════════
   AFFILIATE DISCLOSURE notice (frontend)
   ══════════════════════════════════════════════════════════════════ */

.lwpt-disclosure {
    --d-text:       #0f172a;
    --d-muted:      #475569;
    --d-accent:     #f59e0b;
    --d-accent-2:   #d97706;
    --d-border:     #fde4b5;
    --d-bg:         #fffbeb;
    --d-bg-2:       #fef3c7;
    --d-radius:     12px;

    margin: 1.25rem 0 1.5rem;
    color: var(--d-text);
    line-height: 1.55;
    font-size: 14px;
}

.lwpt-disclosure__inner {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.lwpt-disclosure__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--d-accent-2);
}

.lwpt-disclosure__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.lwpt-disclosure__title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--d-accent-2);
    line-height: 1.2;
}

.lwpt-disclosure__text {
    color: var(--d-muted);
    font-size: 13.5px;
}

.lwpt-disclosure__text a {
    color: var(--d-accent-2);
    text-decoration: underline;
    font-weight: 600;
}

.lwpt-disclosure__text a:hover {
    color: var(--d-text);
}

.lwpt-disclosure__dismiss {
    flex-shrink: 0;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 0;
    background: transparent;
    color: var(--d-muted);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s, color .15s;
    margin-top: -2px;
}

.lwpt-disclosure__dismiss:hover {
    background: rgba(245, 158, 11, .12);
    color: var(--d-accent-2);
}

.lwpt-disclosure__dismiss:focus-visible {
    outline: 2px solid var(--d-accent-2);
    outline-offset: 1px;
}

/* ── Style: SOFT (default) ─ rounded gradient pill ──────────────── */

.lwpt-disclosure--soft .lwpt-disclosure__inner {
    background: linear-gradient(180deg, var(--d-bg) 0%, var(--d-bg-2) 100%);
    border: 1px solid var(--d-border);
    border-radius: var(--d-radius);
    padding: 12px 16px;
    box-shadow: 0 1px 2px rgba(245, 158, 11, .08),
                0 6px 18px rgba(245, 158, 11, .06);
}

/* ── Style: BANNER ─ full-width tinted strip ────────────────────── */

.lwpt-disclosure--banner {
    margin-left: calc(-1 * var(--lwpt-content-pad, 24px));
    margin-right: calc(-1 * var(--lwpt-content-pad, 24px));
}

.lwpt-disclosure--banner .lwpt-disclosure__inner {
    background: linear-gradient(90deg, var(--d-bg-2) 0%, var(--d-bg) 100%);
    border-top: 2px solid var(--d-accent);
    border-bottom: 2px solid var(--d-accent);
    padding: 14px 24px;
    border-radius: 0;
    align-items: center;
}

/* ── Style: CARD ─ bordered box, more substantial ───────────────── */

.lwpt-disclosure--card .lwpt-disclosure__inner {
    background: #fff;
    border: 1.5px solid var(--d-border);
    border-left: 4px solid var(--d-accent);
    border-radius: var(--d-radius);
    padding: 16px 20px;
    box-shadow: 0 4px 12px rgba(245, 158, 11, .08);
}

.lwpt-disclosure--card .lwpt-disclosure__title {
    font-size: 15px;
    text-transform: none;
    letter-spacing: -0.01em;
    color: var(--d-text);
}

/* ── Style: MINIMAL ─ italic single line, no chrome ─────────────── */

.lwpt-disclosure--minimal {
    font-size: 13px;
    color: var(--d-muted);
    font-style: italic;
}

.lwpt-disclosure--minimal .lwpt-disclosure__inner {
    border-left: 3px solid var(--d-accent);
    padding: 4px 0 4px 12px;
    background: transparent;
    align-items: center;
}

.lwpt-disclosure--minimal .lwpt-disclosure__icon {
    color: var(--d-accent-2);
}

.lwpt-disclosure--minimal .lwpt-disclosure__title {
    display: none;
}

/* ── No-icon variant tightens the layout ────────────────────────── */

.lwpt-disclosure--no-icon .lwpt-disclosure__inner {
    /* No padding adjustment needed — the icon span isn't rendered. */
}

/* ── Responsive ─────────────────────────────────────────────────── */

@media (max-width: 640px) {
    .lwpt-disclosure__title { font-size: 12px; }
    .lwpt-disclosure__text  { font-size: 13px; }
    .lwpt-disclosure--banner { margin-left: 0; margin-right: 0; }
    .lwpt-disclosure--banner .lwpt-disclosure__inner {
        padding: 12px 16px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .lwpt-disclosure__dismiss { transition: none; }
}

/* ══════════════════════════════════════════════════════════════════
   TITLE AREA — comprehensive customizable post-title block.
   Driven by CSS variables emitted from inc/title-area.php.
   ══════════════════════════════════════════════════════════════════ */

.lwpt-title-area {
    position: relative;
    margin: 0 0 1.5rem;
    padding: var(--lwpt-ta-pad-top, 32px) var(--lwpt-ta-pad-x, 0) var(--lwpt-ta-pad-bottom, 24px);
    border-radius: var(--lwpt-ta-radius, 0);
    border-bottom: var(--lwpt-ta-border-bottom, 0);
    box-shadow: var(--lwpt-ta-shadow, none);
    overflow: hidden;
}

/* ──────────────────────────────────────────────────────────────────
   Outside-the-container title area — rendered between the site header
   and the article wrapper so the article card sits cleanly below it.
   Spans the full viewport width by default (the inner column controls
   max-width via .lwpt-title-area--width-* modifiers).
   ────────────────────────────────────────────────────────────────── */

.lwpt-title-area--outside {
    margin: 0;
    width: 100%;
    padding-inline: var(--lwpt-ta-pad-x, 1.25rem);
}

.lwpt-title-area--outside .lwpt-title-area__inner {
    max-width: var(--lwpt-content-width, 1200px);
    margin-inline: auto;
}

/* When a title area renders outside, the article wrapper that follows
   should not also reserve a top margin / padding for a title. */

.lwpt-container.lwpt-has-outside-title {
    padding-top: 0;
}

.lwpt-container.lwpt-has-outside-title .lwpt-entry {
    margin-top: 0;
}

/* Pull the article card up slightly so it overlaps the title area's
   bottom edge for a cohesive "card emerges from hero" feel. */

.lwpt-container.lwpt-has-outside-title.lwpt-csty-boxed > .lwpt-entry {
    margin-top: -32px;
    position: relative;
    z-index: 2;
}

.lwpt-title-area--bg-color {
    background-color: var(--lwpt-ta-bg-color, transparent);
}

/* Background image / gradient layer — separated so the overlay sits on top
   while content stays readable. */

.lwpt-title-area__bg {
    position: absolute;
    inset: 0;
    background-image: var(--lwpt-ta-bg-image, none);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 0;
}

.lwpt-title-area__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 1);
    opacity: var(--lwpt-ta-overlay, 0);
    z-index: 0;
    pointer-events: none;
}

.lwpt-title-area__inner {
    position: relative;
    z-index: 1;
    max-width: var(--lwpt-ta-width, none);
    margin-inline: auto;
}

/* Inherit content width when set to "inherit" — the inner column matches
   the article prose column. */

.lwpt-title-area .lwpt-title-area__inner {
    max-width: var(--lwpt-ta-width);
}

.lwpt-title-area[class*="--bg-image"] .lwpt-title-area__inner,
.lwpt-title-area[class*="--bg-gradient"] .lwpt-title-area__inner {
    /* When a hero background is on, vertical flow centers nicely. */
    text-align: inherit;
}

/* ──────────────────────────────────────────────────────────────────
   Full-bleed title area — when the user picks "Full container width"
   we break out of the article column AND the page container so the
   background spans edge-to-edge. The inner content stays centered
   inside `--lwpt-content-width` so the title text doesn't sprawl.
   ────────────────────────────────────────────────────────────────── */

.lwpt-title-area--width-full {
    width: 100vw;
    max-width: 100vw;
    margin-left:  calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    border-radius: 0;
}

/* When we go full bleed, account for the scrollbar on overflow-y pages
   so we don't trigger horizontal scroll. */

@supports (width: 100dvw) {
    .lwpt-title-area--width-full { width: 100dvw; max-width: 100dvw; margin-left: calc(50% - 50dvw); margin-right: calc(50% - 50dvw); }
}

.lwpt-title-area--width-full .lwpt-title-area__inner {
    max-width: var(--lwpt-content-width, 1200px);
    padding-inline: 1.25rem;
}

/* "Wide" title area — span the full container width but stay inside it. */

.lwpt-title-area--width-wide {
    width: auto;
}

.lwpt-title-area--width-wide .lwpt-title-area__inner {
    max-width: 1080px;
}

.lwpt-title-area--width-narrow .lwpt-title-area__inner {
    max-width: 640px;
}

/* When the title area has any background AND the fact-check card is
   rendered immediately AFTER it (the most common config), pull the
   card up so it visually nests against the title block instead of
   leaving an awkward gap. */

.lwpt-title-area--has-bg + .lwpt-factcheck {
    margin-top: -28px;
    position: relative;
    z-index: 2;
}

/* Alignment classes — placed on the wrapper so kicker, title, meta all align. */

.lwpt-title-area--align-left   .lwpt-title-area__inner { text-align: left;   }

.lwpt-title-area--align-center .lwpt-title-area__inner { text-align: center; margin-inline: auto; }

.lwpt-title-area--align-right  .lwpt-title-area__inner { text-align: right;  }

/* When the bg is image or gradient, the entry title should default to white
   for readability — but allow user override via --lwpt-ta-text-color. */

.lwpt-title-area--bg-image .lwpt-entry-title,
.lwpt-title-area--bg-gradient .lwpt-entry-title {
    color: var(--lwpt-ta-text-color, #ffffff);
}

.lwpt-title-area--bg-image .lwpt-title-area__kicker,
.lwpt-title-area--bg-gradient .lwpt-title-area__kicker {
    color: var(--lwpt-ta-kicker-color, rgba(255, 255, 255, .85));
}

.lwpt-title-area--bg-image .lwpt-title-area__meta,
.lwpt-title-area--bg-gradient .lwpt-title-area__meta {
    color: var(--lwpt-ta-meta-color, rgba(255, 255, 255, .8));
}

/* Solid color / no-bg variants honor user color override but fall through
   to the global heading color. */

.lwpt-title-area--bg-none  .lwpt-entry-title,
.lwpt-title-area--bg-color .lwpt-entry-title {
    color: var(--lwpt-ta-text-color, var(--lwpt-color-heading, inherit));
}

.lwpt-entry-title {
    font-size: calc( var(--lwpt-h1-size, 44px) * var(--lwpt-ta-size-mult, 1) );
    font-weight: var(--lwpt-heading-weight, 800);
    line-height: var(--lwpt-heading-line, 1.2);
    margin: 0 0 .35em;
}

.lwpt-title-area__kicker {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--lwpt-ta-kicker-color, var(--lwpt-color-primary, #6366f1));
    margin-bottom: 10px;
}

.lwpt-title-area__meta {
    color: var(--lwpt-ta-meta-color, var(--lwpt-color-muted, #64748b));
    font-size: 13px;
    margin: 8px 0;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.lwpt-title-area--align-center .lwpt-title-area__meta {
    justify-content: center;
}

.lwpt-title-area--align-right .lwpt-title-area__meta {
    justify-content: flex-end;
}

.lwpt-title-area__divider {
    margin-top: 18px;
    height: 2px;
    width: 64px;
    background: var(--lwpt-ta-divider-color, linear-gradient(90deg, var(--lwpt-color-primary, #6366f1), var(--lwpt-color-accent, #8b5cf6)));
    border-radius: 2px;
}

.lwpt-title-area--align-center .lwpt-title-area__divider {
    margin-inline: auto;
}

.lwpt-title-area--align-right .lwpt-title-area__divider {
    margin-left: auto;
}

/* When the fact-check card sits inside the title area, give it a touch of
   transparency so it sits naturally on a colored bg. */

.lwpt-title-area .lwpt-factcheck {
    margin-top: 14px;
    margin-bottom: 0;
    background:
        radial-gradient(ellipse at top left, rgba(255, 255, 255, .4), transparent 55%),
        rgba(255, 255, 255, .82);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border-color: rgba(255, 255, 255, .5);
}

.lwpt-title-area--bg-none .lwpt-factcheck,
.lwpt-title-area--bg-color .lwpt-factcheck {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

/* Responsive padding tightening */

@media (max-width: 640px) {
    .lwpt-title-area {
        padding-top: max(16px, calc(var(--lwpt-ta-pad-top, 32px) * .75));
        padding-bottom: max(16px, calc(var(--lwpt-ta-pad-bottom, 24px) * .75));
    }
    .lwpt-entry-title {
        font-size: calc( var(--lwpt-h1-size, 44px) * var(--lwpt-ta-size-mult, 1) * .82 );
    }
}

/* ════════════════════════════════════════════════════════════════════════════
   Archive card per-design overrides — picks up CSS variables emitted by
   inc/archive-design-css.php on archive / blog / search / home bodies.
   ════════════════════════════════════════════════════════════════════════════ */

body.archive .lwpt-card,
body.blog    .lwpt-card,
body.search  .lwpt-card,
body.home    .lwpt-card {
    background:    var(--lwpt-a-card-bg, var(--lwpt-color-card-bg, #fff));
    border:        var(--lwpt-a-card-border, 1px solid var(--lwpt-color-border, #e2e8f0));
    border-radius: var(--lwpt-a-card-radius, 12px);
    box-shadow:    var(--lwpt-a-card-shadow, 0 1px 2px rgba(15,23,42,.04));
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

body.archive .lwpt-card .lwpt-card__title,
body.blog    .lwpt-card .lwpt-card__title,
body.search  .lwpt-card .lwpt-card__title,
body.home    .lwpt-card .lwpt-card__title { color: var(--lwpt-a-card-title, inherit); }

body.archive .lwpt-card .lwpt-card__excerpt,
body.blog    .lwpt-card .lwpt-card__excerpt,
body.search  .lwpt-card .lwpt-card__excerpt,
body.home    .lwpt-card .lwpt-card__excerpt { color: var(--lwpt-a-card-excerpt, var(--lwpt-color-muted, #475569)); }

/* Card grid gap controlled per archive */

body.archive .lwpt-archive-grid,
body.blog    .lwpt-archive-grid,
body.home    .lwpt-archive-grid,
body.search  .lwpt-archive-grid { gap: var(--lwpt-a-card-gap, 24px); }

/* Hover effects (driven by --lwpt-a-card-hover keyword set by PHP) */

body.archive .lwpt-card:hover,
body.blog    .lwpt-card:hover,
body.search  .lwpt-card:hover,
body.home    .lwpt-card:hover {
    /* Default lift; specific keywords below override. */
    transform: translateY(-3px);
    box-shadow: 0 12px 32px rgba(15,23,42,.10);
}

body[class*="--card-hover-none"] .lwpt-card:hover { transform: none; box-shadow: var(--lwpt-a-card-shadow, 0 1px 2px rgba(15,23,42,.04)); }

.lwpt-archive-card-hover-glow .lwpt-card:hover  { transform: none; box-shadow: 0 0 0 2px rgba(99,102,241,.18), 0 14px 32px rgba(99,102,241,.18); }

.lwpt-archive-card-hover-border .lwpt-card:hover { transform: none; border-color: var(--lwpt-color-primary, #6366f1); box-shadow: var(--lwpt-a-card-shadow, none); }

.lwpt-archive-card-hover-tilt .lwpt-card:hover  { transform: perspective(800px) rotateX(2deg) rotateY(-2deg) translateY(-2px); }

.lwpt-archive-card-hover-none .lwpt-card:hover  { transform: none; box-shadow: var(--lwpt-a-card-shadow, none); }

.hover\:border-primary:hover {
  border-color: var(--lwpt-color-primary, #4f46e5);
}

.hover\:bg-surface-2:hover {
  background-color: var(--lwpt-color-bg-alt, #f8fafc);
}

.hover\:text-primary:hover {
  color: var(--lwpt-color-primary, #4f46e5);
}

.hover\:shadow-lg:hover {
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

@media (min-width: 768px) {

  .md\:sticky {
    position: sticky;
  }

  .md\:-mx-0 {
    margin-left: -0px;
    margin-right: -0px;
  }

  .md\:mx-0 {
    margin-left: 0px;
    margin-right: 0px;
  }

  .md\:block {
    display: block;
  }

  .md\:hidden {
    display: none;
  }

  .md\:h-\[55vh\] {
    height: 55vh;
  }

  .md\:h-full {
    height: 100%;
  }

  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .md\:grid-cols-\[1fr_var\(--lwpt-sidebar-width\2c 320px\)\] {
    grid-template-columns: 1fr var(--lwpt-sidebar-width,320px);
  }

  .md\:grid-cols-\[280px_1fr\] {
    grid-template-columns: 280px 1fr;
  }

  .md\:grid-cols-\[var\(--lwpt-sidebar-width\2c 320px\)_1fr\] {
    grid-template-columns: var(--lwpt-sidebar-width,320px) 1fr;
  }

  .md\:flex-row {
    flex-direction: row;
  }

  .md\:p-6 {
    padding: 1.5rem;
  }

  .md\:text-right {
    text-align: right;
  }

  .md\:text-9xl {
    font-size: 8rem;
    line-height: 1;
  }
}

@media (min-width: 1024px) {

  .lg\:flex {
    display: flex;
  }
}

@media (min-width: 1280px) {

  .xl\:block {
    display: block;
  }
}
