/**
 * Unibautista Theme for OJS
 * Developed by IngeWeb - https://IngeWeb.co
 * Branding: Fundación Universitaria Seminario Teológico Bautista Internacional
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Lora:wght@400;500;600;700&family=Montserrat:wght@300;400;500;600;700;800&family=Pontano+Sans:wght@300;400;500;600;700&family=Poppins:wght@300;400;500;600;700&family=Source+Serif+4:wght@400;500;600;700&display=swap');

/* ============================================
   VARIABLES
   ============================================ */
:root {
    --ub-primary: #1E73BE;
    --ub-dark: #0056A7;
    --ub-deep: #085190;
    --ub-bright: #1674D1;
    --ub-light: #e8f1fa;
    --ub-lighter: #f0f6fc;
    --ub-text: #111111;
    --ub-text2: #444444;
    --ub-muted: #999999;
    --ub-hero-bg: var(--ub-primary);
    --ub-radius: 6px;
}

/* ============================================
   COLOR SCHEMES (driven by html class)
   ============================================ */
html.ub-color-blue { /* default — no override needed */ }

html.ub-color-green {
    --ub-primary: #16a34a;
    --ub-dark: #15803d;
    --ub-deep: #166534;
    --ub-bright: #22c55e;
    --ub-light: #dcfce7;
    --ub-lighter: #f0fdf4;
}

html.ub-color-indigo {
    --ub-primary: #6366f1;
    --ub-dark: #4f46e5;
    --ub-deep: #4338ca;
    --ub-bright: #818cf8;
    --ub-light: #e0e7ff;
    --ub-lighter: #eef2ff;
}

html.ub-color-sky {
    --ub-primary: #0ea5e9;
    --ub-dark: #0284c7;
    --ub-deep: #0369a1;
    --ub-bright: #38bdf8;
    --ub-light: #e0f2fe;
    --ub-lighter: #f0f9ff;
}

html.ub-color-orange {
    --ub-primary: #ea580c;
    --ub-dark: #c2410c;
    --ub-deep: #9a3412;
    --ub-bright: #f97316;
    --ub-light: #ffedd5;
    --ub-lighter: #fff7ed;
}

/* ============================================
   FONT FAMILIES (driven by html class)
   ============================================ */
html.ub-font-pontano-sans body,
html.ub-font-pontano-sans .prose,
html.ub-font-pontano-sans .prose p,
html.ub-font-pontano-sans .prose li {
    font-family: 'Pontano Sans', 'Poppins', sans-serif !important;
}

html.ub-font-montserrat body,
html.ub-font-montserrat .prose,
html.ub-font-montserrat .prose p,
html.ub-font-montserrat .prose li {
    font-family: 'Montserrat', sans-serif !important;
}

html.ub-font-poppins body,
html.ub-font-poppins .prose,
html.ub-font-poppins .prose p,
html.ub-font-poppins .prose li {
    font-family: 'Poppins', sans-serif !important;
}

html.ub-font-inter body,
html.ub-font-inter .prose,
html.ub-font-inter .prose p,
html.ub-font-inter .prose li {
    font-family: 'Inter', sans-serif !important;
}

html.ub-font-lora body,
html.ub-font-lora .prose,
html.ub-font-lora .prose p,
html.ub-font-lora .prose li {
    font-family: 'Lora', Georgia, serif !important;
}

html.ub-font-source-serif body,
html.ub-font-source-serif .prose,
html.ub-font-source-serif .prose p,
html.ub-font-source-serif .prose li {
    font-family: 'Source Serif 4', Georgia, serif !important;
}

/* Headings always use Montserrat regardless of body font */
h1, h2, h3, h4, h5, h6, .font-display {
    font-family: 'Montserrat', 'Pontano Sans', sans-serif !important;
}

.prose h1, .prose h2, .prose h3, .prose h4 {
    font-family: 'Montserrat', sans-serif !important;
}

/* Override material theme font classes */
.font-comic-neue, .font-comic-sans, .font-cardo,
.font-cormorant, .font-old-standard-tt, .font-roboto-serif {
    font-family: inherit !important;
}

/* ============================================
   INPUTS — Unified
   ============================================ */
.ub-input {
    border: 1px solid #d1d5db;
    border-radius: var(--ub-radius);
    padding: 0.5rem 0.75rem;
    font-size: 14px;
    line-height: 1.5;
    color: var(--ub-text);
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
    transition: border-color 0.2s, box-shadow 0.2s;
    outline: none;
}

.ub-input:focus {
    border-color: var(--ub-primary) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--ub-primary) 15%, transparent) !important;
}

.dark .ub-input {
    background: #1f2937;
    border-color: #6b7280;
    color: #fff;
}

/* ============================================
   BUTTONS — Unified System
   ============================================ */

/* Base button */
.ub-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.625rem 1.5rem;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none !important;
    transition: all 0.25s ease;
    cursor: pointer;
    border: 2px solid transparent;
    line-height: 1.4;
}

/* Button shapes */
.ub-btn--rounded { border-radius: var(--ub-radius); }
.ub-btn--pill { border-radius: 50px; }
.ub-btn--square { border-radius: 0; }

/* Primary button (solid white — for hero) */
.ub-btn--primary {
    background: #fff;
    color: var(--ub-dark);
    border-color: #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.ub-btn--primary:hover {
    background: var(--ub-light);
    border-color: var(--ub-light);
    color: var(--ub-deep);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

/* Outline button (transparent — for hero) */
.ub-btn--outline {
    background: rgba(255,255,255,0.1);
    color: #fff;
    border-color: rgba(255,255,255,0.5);
}
.ub-btn--outline:hover {
    background: rgba(255,255,255,0.2);
    border-color: #fff;
    color: #fff;
    transform: translateY(-1px);
}

/* Blue button (for content areas — form submits, links) */
.ub-btn--blue {
    background: var(--ub-primary);
    color: #fff;
    border-color: var(--ub-primary);
}
.ub-btn--blue:hover {
    background: var(--ub-dark);
    border-color: var(--ub-dark);
    color: #fff;
    transform: translateY(-1px);
}

/* Secondary button (for login/register secondary actions) */
.ub-btn--secondary {
    background: transparent;
    color: var(--ub-primary);
    border: 2px solid var(--ub-primary);
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px;
    font-weight: 600;
    padding: 0.625rem 1.5rem;
    letter-spacing: 0.02em;
    text-decoration: none !important;
    transition: all 0.25s ease;
    cursor: pointer;
    line-height: 1.4;
}
.ub-btn--secondary:hover {
    background: var(--ub-primary);
    color: #fff;
    border-color: var(--ub-primary);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px color-mix(in srgb, var(--ub-primary) 25%, transparent);
}

/* ============================================
   MATERIAL BUTTON OVERRIDES (Tailwind classes)
   ============================================ */

/* Primary submit buttons (from {material_button_primary}) */
.bg-blue-300,
button.bg-blue-300,
a.bg-blue-300,
button[class*="bg-blue-300"],
.rounded-full[class*="bg-blue-300"] {
    background-color: var(--ub-primary) !important;
    color: #fff !important;
    border-radius: var(--ub-radius) !important;
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    letter-spacing: 0.02em;
    padding: 0.625rem 1.5rem !important;
    transition: all 0.25s ease !important;
    border: 2px solid var(--ub-primary) !important;
}

/* Button style variants for material buttons */
.ub-buttons-pill .bg-blue-300,
.ub-buttons-pill button.bg-blue-300,
.ub-buttons-pill a.bg-blue-300,
.ub-buttons-pill .rounded-full[class*="bg-blue-300"] {
    border-radius: 50px !important;
}

.ub-buttons-square .bg-blue-300,
.ub-buttons-square button.bg-blue-300,
.ub-buttons-square a.bg-blue-300,
.ub-buttons-square .rounded-full[class*="bg-blue-300"] {
    border-radius: 0 !important;
}

/* Galley/PDF buttons also respect button style */
.ub-buttons-pill a.obj_galley_link { border-radius: 50px; }
.ub-buttons-square a.obj_galley_link { border-radius: 0; }

.hover\:bg-blue-200:hover {
    background-color: var(--ub-dark) !important;
    color: #fff !important;
    border-color: var(--ub-dark) !important;
    transform: translateY(-1px);
}

.active\:bg-blue-500:active {
    background-color: var(--ub-deep) !important;
}

/* Secondary nav buttons (header) — Classic style (default) */
.ub-nav--classic .shadow-md.shadow-black\/5.ring-1 {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    letter-spacing: 0.02em;
    border: 1.5px solid var(--ub-primary) !important;
    color: var(--ub-primary) !important;
    box-shadow: none !important;
    padding: 0.4rem 1rem !important;
    border-radius: var(--ub-radius) !important;
    transition: all 0.2s ease !important;
    --tw-ring-shadow: 0 0 #0000 !important;
}

.ub-nav--classic .shadow-md.shadow-black\/5.ring-1:hover {
    background-color: var(--ub-primary) !important;
    color: #fff !important;
    transform: translateY(-1px);
}

/* Galley / PDF buttons */
a.obj_galley_link {
    background-color: var(--ub-primary) !important;
    color: #fff !important;
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    border-radius: var(--ub-radius) !important;
    padding: 0.5rem 1.25rem !important;
    border: 2px solid var(--ub-primary) !important;
    display: inline-flex !important;
    align-items: center;
    gap: 0.4rem;
    transition: all 0.25s ease !important;
    text-decoration: none !important;
}

a.obj_galley_link:hover {
    background-color: var(--ub-dark) !important;
    border-color: var(--ub-dark) !important;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px color-mix(in srgb, var(--ub-primary) 30%, transparent);
}

/* ============================================
   PASSWORD TOGGLE
   ============================================ */
.ub-pw-toggle {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    padding: 0.25rem;
    cursor: pointer;
    color: var(--ub-muted);
    transition: color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ub-pw-toggle:hover {
    color: var(--ub-primary);
}

[x-cloak] { display: none !important; }

/* ============================================
   HERO BANNER — Common
   ============================================ */
.ub-hero {
    background-color: var(--ub-hero-bg, var(--ub-primary));
    background-size: cover;
    background-position: center;
}

.ub-hero .font-display.text-5xl,
.ub-hero .font-display {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 800 !important;
    text-shadow: 0 2px 12px rgba(0,0,0,0.15);
}

/* Hero title & subtitle (avoids relying on uncompiled Tailwind) */
.ub-hero-title {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 800 !important;
    font-size: 3rem !important;
    line-height: 1.1 !important;
    text-shadow: 0 2px 12px rgba(0,0,0,0.15);
}

@media (min-width: 640px) {
    .ub-hero-title { font-size: 3.5rem !important; }
}

@media (min-width: 1024px) {
    .ub-hero-title { font-size: 4rem !important; }
}

.ub-hero-subtitle {
    font-size: 1.125rem;
    line-height: 1.7;
}

/* --- HERO: Centered --- */
.ub-hero--centered {
    background: linear-gradient(135deg, var(--ub-dark) 0%, var(--ub-primary) 50%, var(--ub-bright) 100%);
}

/* --- HERO: Editorial --- */
.ub-hero--editorial {
    background: linear-gradient(135deg, var(--ub-deep) 0%, var(--ub-dark) 40%, var(--ub-primary) 100%);
}

.ub-hero-accent-bar {
    width: 60px;
    height: 4px;
    background: rgba(255,255,255,0.6);
    border-radius: 2px;
    margin-bottom: 1.25rem;
}

.ub-hero-editorial-deco {
    position: absolute;
    right: -5%;
    top: -20%;
    width: 50%;
    height: 140%;
    background: rgba(255,255,255,0.03);
    transform: skewX(-12deg);
    pointer-events: none;
}

/* --- HERO: Magazine --- */
.ub-hero--magazine {
    background: linear-gradient(160deg, var(--ub-dark) 0%, var(--ub-primary) 60%, var(--ub-bright) 100%);
}

.ub-hero-magazine-img {
    position: relative;
}

.ub-hero-magazine-img::before {
    content: '';
    position: absolute;
    inset: -8px;
    border: 2px solid rgba(255,255,255,0.15);
    border-radius: 12px;
}

.ub-hero-magazine-img img {
    border-radius: 8px;
}

.ub-hero-magazine-graphic {
    opacity: 0.8;
}

/* ============================================
   TEXT COLORS (Tailwind overrides)
   ============================================ */
.text-blue-400 { color: var(--ub-primary) !important; }
.text-blue-500 { color: var(--ub-dark) !important; }
.text-blue-600 { color: var(--ub-deep) !important; }

.prose-a\:text-blue-400 :is(:where(a):not(:where([class~="not-prose"],[class~="not-prose"] *))) {
    color: var(--ub-primary) !important;
}

.prose-a\:text-blue-400 :is(:where(a):not(:where([class~="not-prose"],[class~="not-prose"] *))):hover {
    color: var(--ub-dark) !important;
}

.before\:bg-blue-500::before {
    background-color: var(--ub-primary) !important;
}

.focus\:border-blue-300:focus {
    border-color: var(--ub-primary) !important;
}

.focus\:ring-blue-200:focus {
    --tw-ring-color: color-mix(in srgb, var(--ub-primary) 30%, transparent) !important;
}

/* Prose link colors — excludes not-prose elements (e.g. galley buttons) */
.ub-prose :where(a):not(:where([class~="not-prose"], [class~="not-prose"] *, .obj_galley_link, .obj_galley_link_supplementary)) {
    color: var(--ub-primary) !important;
}
.ub-prose :where(a):not(:where([class~="not-prose"], [class~="not-prose"] *, .obj_galley_link, .obj_galley_link_supplementary)):hover {
    color: var(--ub-dark) !important;
}

/* Utility classes for dynamic theme color (replaces dynamic Tailwind classes) */
.ub-text-primary { color: var(--ub-primary) !important; }
.ub-text-dark    { color: var(--ub-dark) !important; }
.ub-fill-primary { fill: var(--ub-primary) !important; }
a.ub-text-primary:hover { color: var(--ub-dark) !important; }

/* Missing Tailwind max-w-* classes (not in compiled CSS) */
.max-w-sm  { max-width: 24rem; }   /* 384px */
.max-w-md  { max-width: 28rem; }   /* 448px */
.max-w-lg  { max-width: 32rem; }   /* 512px */
.max-w-xl  { max-width: 36rem; }   /* 576px */
.max-w-6xl { max-width: 72rem; }   /* 1152px */

/* ============================================
   HEADER — Base
   ============================================ */
.ub-nav .pkp_navigation_primary a,
.ub-nav .pkp_navigation_user a {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 500;
}

/* Search icon — all navbar styles */
.pkp_navigation_search_wrapper a {
    width: 36px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    padding: 0 !important;
    transition: all 0.2s ease !important;
}

.pkp_navigation_search_wrapper a svg {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px;
}

/* ============================================
   NAVBAR: Classic
   ============================================ */
.ub-nav--classic {
    border-bottom: 2px solid var(--ub-primary);
}

.ub-nav--classic .pkp_navigation_search_wrapper a {
    background: transparent !important;
    border: 1.5px solid var(--ub-primary) !important;
    color: var(--ub-primary) !important;
    box-shadow: none !important;
    --tw-ring-shadow: 0 0 #0000 !important;
}

.ub-nav--classic .pkp_navigation_search_wrapper a:hover {
    background: var(--ub-primary) !important;
    color: #fff !important;
}

/* ============================================
   NAVBAR: Solid (branded background)
   ============================================ */
.ub-nav--solid {
    background: linear-gradient(135deg, var(--ub-dark) 0%, var(--ub-primary) 100%) !important;
    border-bottom: none;
    box-shadow: 0 2px 12px color-mix(in srgb, var(--ub-primary) 30%, transparent) !important;
}

.ub-nav--solid .pkp_navigation_primary a,
.ub-nav--solid .pkp_navigation_user a {
    color: rgba(255,255,255,0.9) !important;
}

.ub-nav--solid .pkp_navigation_primary a:hover,
.ub-nav--solid .pkp_navigation_user a:hover {
    color: #fff !important;
}

.ub-nav--solid .shadow-md.shadow-black\/5.ring-1 {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    background: rgba(255,255,255,0.15) !important;
    border: 1.5px solid rgba(255,255,255,0.4) !important;
    color: #fff !important;
    box-shadow: none !important;
    padding: 0.4rem 1rem !important;
    border-radius: var(--ub-radius) !important;
    transition: all 0.2s ease !important;
}

.ub-nav--solid .shadow-md.shadow-black\/5.ring-1:hover {
    background: rgba(255,255,255,0.25) !important;
    border-color: rgba(255,255,255,0.7) !important;
    color: #fff !important;
    transform: translateY(-1px);
}

.ub-nav--solid .pkp_navigation_search_wrapper a {
    background: rgba(255,255,255,0.15) !important;
    border: 1.5px solid rgba(255,255,255,0.4) !important;
    color: #fff !important;
    box-shadow: none !important;
}

.ub-nav--solid .pkp_navigation_search_wrapper a:hover {
    background: rgba(255,255,255,0.3) !important;
    border-color: rgba(255,255,255,0.7) !important;
}

/* Solid navbar: logo text white */
.ub-nav--solid .font-display.text-slate-900,
.ub-nav--solid a.font-display {
    color: #fff !important;
}

/* Solid navbar: hamburger & theme toggle */
.ub-nav--solid .stroke-slate-500 {
    stroke: rgba(255,255,255,0.85) !important;
}

.ub-nav--solid button[aria-label*="theme"],
.ub-nav--solid .text-slate-500 {
    color: rgba(255,255,255,0.85) !important;
}

/* ============================================
   NAVBAR: Minimal (clean, no borders)
   ============================================ */
.ub-nav--minimal {
    border-bottom: 1px solid #e5e7eb;
    box-shadow: none !important;
}

.ub-nav--minimal .shadow-md.shadow-black\/5.ring-1 {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    background: transparent !important;
    border: none !important;
    color: var(--ub-text2) !important;
    box-shadow: none !important;
    padding: 0.4rem 0.75rem !important;
    border-radius: var(--ub-radius) !important;
    transition: all 0.2s ease !important;
    position: relative;
}

.ub-nav--minimal .shadow-md.shadow-black\/5.ring-1::after {
    content: '';
    position: absolute;
    bottom: 2px;
    left: 50%;
    width: 0;
    height: 2px;
    background: var(--ub-primary);
    transition: all 0.25s ease;
    transform: translateX(-50%);
}

.ub-nav--minimal .shadow-md.shadow-black\/5.ring-1:hover {
    color: var(--ub-primary) !important;
    background: transparent !important;
    transform: none;
}

.ub-nav--minimal .shadow-md.shadow-black\/5.ring-1:hover::after {
    width: 80%;
}

.ub-nav--minimal .pkp_navigation_search_wrapper a {
    background: transparent !important;
    border: none !important;
    color: var(--ub-text2) !important;
    box-shadow: none !important;
}

.ub-nav--minimal .pkp_navigation_search_wrapper a:hover {
    color: var(--ub-primary) !important;
    background: var(--ub-lighter) !important;
}

/* ============================================
   NAVBAR: Glass (frosted glass / glassmorphism)
   ============================================ */
.ub-nav--glass {
    background: rgba(255, 255, 255, 0.7) !important;
    backdrop-filter: blur(12px) saturate(180%);
    -webkit-backdrop-filter: blur(12px) saturate(180%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.08) !important;
}

.ub-nav--glass .pkp_navigation_primary a,
.ub-nav--glass .pkp_navigation_user a {
    color: var(--ub-dark) !important;
}

.ub-nav--glass .pkp_navigation_primary a:hover,
.ub-nav--glass .pkp_navigation_user a:hover {
    color: var(--ub-primary) !important;
}

.ub-nav--glass .shadow-md.shadow-black\/5.ring-1 {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    background: rgba(255, 255, 255, 0.35) !important;
    border: 1.5px solid rgba(var(--ub-primary-rgb, 59,130,246), 0.25) !important;
    color: var(--ub-dark) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
    padding: 0.4rem 1rem !important;
    border-radius: var(--ub-radius) !important;
    transition: all 0.2s ease !important;
    --tw-ring-shadow: 0 0 #0000 !important;
}

.ub-nav--glass .shadow-md.shadow-black\/5.ring-1:hover {
    background: rgba(var(--ub-primary-rgb, 59,130,246), 0.12) !important;
    border-color: var(--ub-primary) !important;
    color: var(--ub-primary) !important;
    transform: translateY(-1px);
}

.ub-nav--glass .pkp_navigation_search_wrapper a {
    background: rgba(255, 255, 255, 0.35) !important;
    border: 1.5px solid rgba(var(--ub-primary-rgb, 59,130,246), 0.25) !important;
    color: var(--ub-dark) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
}

.ub-nav--glass .pkp_navigation_search_wrapper a:hover {
    background: rgba(var(--ub-primary-rgb, 59,130,246), 0.12) !important;
    color: var(--ub-primary) !important;
}

/* ============================================
   NAVBAR: Transparent (overlays hero)
   ============================================ */
.ub-nav--transparent {
    background: transparent !important;
    border-bottom: none !important;
    box-shadow: none !important;
    position: absolute !important;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
}

.ub-nav--transparent .pkp_navigation_primary a,
.ub-nav--transparent .pkp_navigation_user a {
    color: rgba(255, 255, 255, 0.9) !important;
    text-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.ub-nav--transparent .pkp_navigation_primary a:hover,
.ub-nav--transparent .pkp_navigation_user a:hover {
    color: #fff !important;
}

.ub-nav--transparent .shadow-md.shadow-black\/5.ring-1 {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    background: rgba(255, 255, 255, 0.15) !important;
    border: 1.5px solid rgba(255, 255, 255, 0.4) !important;
    color: #fff !important;
    box-shadow: none !important;
    padding: 0.4rem 1rem !important;
    border-radius: var(--ub-radius) !important;
    transition: all 0.2s ease !important;
    --tw-ring-shadow: 0 0 #0000 !important;
    text-shadow: 0 1px 3px rgba(0,0,0,0.15);
}

.ub-nav--transparent .shadow-md.shadow-black\/5.ring-1:hover {
    background: rgba(255, 255, 255, 0.25) !important;
    border-color: rgba(255, 255, 255, 0.7) !important;
    color: #fff !important;
    transform: translateY(-1px);
}

.ub-nav--transparent .pkp_navigation_search_wrapper a {
    background: rgba(255, 255, 255, 0.15) !important;
    border: 1.5px solid rgba(255, 255, 255, 0.4) !important;
    color: #fff !important;
    box-shadow: none !important;
}

.ub-nav--transparent .pkp_navigation_search_wrapper a:hover {
    background: rgba(255, 255, 255, 0.3) !important;
    border-color: rgba(255, 255, 255, 0.7) !important;
}

/* Transparent navbar: logo text white */
.ub-nav--transparent .font-display.text-slate-900,
.ub-nav--transparent a.font-display {
    color: #fff !important;
    text-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

/* Transparent navbar: hamburger & theme toggle */
.ub-nav--transparent .stroke-slate-500 {
    stroke: rgba(255, 255, 255, 0.85) !important;
}

.ub-nav--transparent button[aria-label*="theme"],
.ub-nav--transparent .text-slate-500 {
    color: rgba(255, 255, 255, 0.85) !important;
}

/* Transparent navbar: hero needs top padding to account for overlay */
.ub-nav--transparent ~ #ub-hero,
.ub-nav--transparent ~ * #ub-hero {
    padding-top: 5rem;
}

/* ============================================
   RESPONSIVE OVERRIDES (missing from compiled Tailwind)
   ============================================ */
@media (min-width: 1024px) {
    .lg\:flex-row    { flex-direction: row !important; }
    .lg\:text-left   { text-align: left !important; }
    .lg\:justify-start { justify-content: flex-start !important; }
    .lg\:gap-12      { gap: 3rem !important; }
    .lg\:max-w-sm    { max-width: 24rem !important; }
}

.gap-4  { gap: 1rem; }
.gap-8  { gap: 2rem; }

/* ============================================
   SIDEBAR
   ============================================ */
nav.w-56 .font-display,
.space-y-9 .font-display {
    font-family: 'Montserrat', sans-serif !important;
    color: var(--ub-dark) !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
}

nav.w-56 .before\:bg-blue-500::before,
.space-y-9 .before\:bg-blue-500::before {
    background-color: var(--ub-primary) !important;
}

/* ============================================
   SIDEBAR POSITION (left/right)
   ============================================ */
.ub-sidebar-left {
    flex-direction: row-reverse;
}

/* Hide the misplaced bg-slate-50 background (it covers main content in row-reverse) */
.ub-sidebar-left > div:first-child .bg-slate-50 {
    display: none !important;
}

.ub-sidebar-left > .ub-sidebar {
    margin-right: 0 !important;
    margin-left: -1.5rem;
    padding-right: 0;
    padding-left: 1.5rem;
    position: relative;
    z-index: 1;
    /* Create mirrored gray background extending to the left viewport edge */
    background-color: rgb(248, 250, 252);
    box-shadow: -50vw 0 0 0 rgb(248, 250, 252);
}

.dark .ub-sidebar-left > .ub-sidebar {
    background-color: transparent;
    box-shadow: none;
}

/* Mirror the dark-mode border decorations to the sidebar's left edge */
.ub-sidebar-left > div:first-child [class*="bg-gradient-to-t"],
.ub-sidebar-left > div:first-child [class*="bg-slate-800"] {
    display: none !important;
}

.ub-sidebar-left > .ub-sidebar::before {
    content: '';
    display: none;
    position: absolute;
    top: 4rem;
    bottom: 0;
    right: 0;
    width: 1px;
    background-color: rgb(30, 41, 59); /* slate-800 */
}
.dark .ub-sidebar-left > .ub-sidebar::before {
    display: block;
}

.ub-sidebar-left > main {
    padding-right: 4rem;
    padding-left: 2rem;
    position: relative;
    z-index: 1;
}

/* ============================================
   FOOTER
   ============================================ */
.ub-footer {
    background-color: var(--ub-primary);
    color: #fff;
    font-family: 'Pontano Sans', sans-serif;
}

.ub-footer-top {
    max-width: 1200px;
    margin: 0 auto;
    padding: 3rem 2rem 2rem;
}

.ub-footer-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap: 2.5rem;
}

@media (max-width: 768px) {
    .ub-footer-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
}

.ub-footer-heading {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #fff !important;
    margin: 0 0 1rem 0;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid rgba(255,255,255,0.25);
}

.ub-footer-text {
    font-size: 14px;
    line-height: 1.7;
    color: rgba(255,255,255,0.85) !important;
    margin: 0 0 1.2rem 0;
}

.ub-footer-text a {
    color: rgba(255,255,255,0.9) !important;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.ub-footer-text a:hover {
    color: #fff !important;
}

.ub-footer-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.ub-footer-list li {
    font-size: 14px;
    color: rgba(255,255,255,0.85);
    padding: 0.35rem 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ub-footer-list li svg { flex-shrink: 0; opacity: 0.7; }

.ub-footer-list li a {
    color: rgba(255,255,255,0.85) !important;
    text-decoration: none;
    transition: color 0.2s ease;
}

.ub-footer-list li a:hover {
    color: #fff !important;
    text-decoration: underline;
}

.ub-footer-social {
    display: flex;
    gap: 0.6rem;
    margin-top: 0.5rem;
}

.ub-footer-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    color: #fff !important;
    transition: background 0.2s ease, transform 0.2s ease;
}

.ub-footer-social a:hover {
    background: rgba(255,255,255,0.3);
    transform: translateY(-2px);
}

.ub-footer-bottom {
    background: var(--ub-dark);
    text-align: center;
    padding: 1rem 2rem;
    font-size: 13px;
    color: rgba(255,255,255,0.7);
}

.ub-footer-bottom p {
    margin: 0.15rem 0;
    color: rgba(255,255,255,0.7) !important;
}

.ub-footer-bottom a {
    color: rgba(255,255,255,0.9) !important;
    text-decoration: none;
}

.ub-footer-bottom a:hover {
    color: #fff !important;
    text-decoration: underline;
}

.ub-footer-credits { font-size: 12px; opacity: 0.6; }

/* ============================================
   FORMS
   ============================================ */
input:focus, select:focus, textarea:focus {
    border-color: var(--ub-primary) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--ub-primary) 15%, transparent) !important;
}

/* ============================================
   LOGIN / AUTH PAGES — Consistent styling
   ============================================ */
.page_login, .page_register {
    border-top: 3px solid var(--ub-primary);
}

.page_login h1, .page_register h1 {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 700 !important;
    color: var(--ub-dark);
}

.page_login a:not(.ub-btn):not([class*="bg-"]),
.page_register a:not(.ub-btn):not([class*="bg-"]) {
    color: var(--ub-primary);
}

.page_login a:not(.ub-btn):not([class*="bg-"]):hover,
.page_register a:not(.ub-btn):not([class*="bg-"]):hover {
    color: var(--ub-dark);
}

/* ============================================
   LOGIN LAYOUTS
   ============================================ */

/* Common login elements */
.ub-login-title {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.5rem;
    color: var(--ub-dark);
}

.ub-login-subtitle {
    font-size: 14px;
    color: var(--ub-muted);
}

/* --- LOGIN: Background image support --- */
.ub-login-has-bg {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* --- LOGIN: Card --- */
.ub-login-card {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ub-login-card.ub-login-has-bg {
    position: relative;
}

.ub-login-card.ub-login-has-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
}

.ub-login-card-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding: 2rem;
}

.ub-login-card-inner .page_login {
    border-top: none !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.10) !important;
}

/* --- LOGIN: Split --- */
.ub-login-split {
    display: flex;
    min-height: 100vh;
    width: 100%;
}

.ub-login-split-brand {
    display: none;
    width: 45%;
    background: linear-gradient(135deg, var(--ub-deep) 0%, var(--ub-dark) 40%, var(--ub-primary) 100%);
    color: #fff;
    position: relative;
    overflow: hidden;
}

.ub-login-split-brand.ub-login-has-bg {
    background-size: cover;
    background-position: center;
}

.ub-login-split-brand.ub-login-has-bg .ub-login-split-brand-inner {
    background: rgba(0,56,100,0.7);
}

.ub-login-split-brand::after {
    content: '';
    position: absolute;
    right: -10%;
    top: -20%;
    width: 50%;
    height: 140%;
    background: rgba(255,255,255,0.04);
    transform: skewX(-12deg);
    pointer-events: none;
}

.ub-login-split-brand-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: 3rem;
    text-align: center;
}

.ub-login-split-brand-inner img {
    max-width: 120px;
    height: auto;
    margin-bottom: 1.5rem;
}

.ub-login-split-title {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 800 !important;
    font-size: 2rem;
    color: #fff !important;
    margin-top: 1rem;
    line-height: 1.2;
}

.ub-login-split-desc {
    font-size: 15px;
    color: rgba(255,255,255,0.8);
    margin-top: 1rem;
    max-width: 320px;
    line-height: 1.6;
}

.ub-login-split-form {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    background: #f9fafb;
}

.ub-login-split-form .page_login {
    border-top: none;
    background: #fff;
    padding: 2rem;
    border-radius: var(--ub-radius);
    box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}

@media (min-width: 768px) {
    .ub-login-split-brand {
        display: flex;
    }
}

/* --- LOGIN: Minimal --- */
.ub-login-minimal {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    padding: 2rem;
    position: relative;
}

.ub-login-minimal.ub-login-has-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.85);
}

.ub-login-minimal-inner {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 400px;
    text-align: center;
}

.ub-login-minimal-inner img {
    max-width: 80px;
    height: auto;
    margin: 0 auto;
}

.ub-login-minimal .page_login {
    border-top: none;
    background: transparent;
    box-shadow: none;
    text-align: left;
}

.ub-login-minimal .page_login h1 {
    text-align: center;
}

.ub-login-minimal .ub-login-subtitle {
    text-align: center;
}

.ub-login-minimal .buttons {
    justify-content: center;
}

/* ============================================
   SCROLLBAR
   ============================================ */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: #f4f4f4; }
::-webkit-scrollbar-thumb { background: var(--ub-primary); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--ub-dark); }

/* ============================================
   SMOOTH TRANSITIONS
   ============================================ */
a, button { transition: all 0.2s ease; }
