:root { --color-navy:       #1c1468;
--color-blue:       #1000f0;
--color-violet:     #5000b3;
--color-pink:       #f9daea;
--color-green:      #00661f;
--color-black:      #101820;
--color-white:      #fbfdfe; --color-navy-dark:  #120e4a;
--color-blue-light: #3d2ff3;
--color-bg:         #fbfdfe;
--color-surface:    #f4f4f8;
--color-border:     #e0e0ec;
--color-text:       #101820;
--color-text-muted: #5a5a72; --font-primary:     'Lexend', system-ui, sans-serif;
--font-logo:        'Aristotelica Pro Display', 'Lexend', sans-serif;
--font-mono:        'JetBrains Mono', 'Courier New', monospace;
--text-xs:   .75rem;
--text-sm:   .875rem;
--text-base: 1rem;
--text-lg:   1.125rem;
--text-xl:   1.25rem;
--text-2xl:  1.5rem;
--text-3xl:  1.875rem;
--text-4xl:  2.25rem;
--text-5xl:  3rem;
--leading-tight:  1.25;
--leading-normal: 1.6;
--leading-loose:  1.8; --space-1:  .25rem;
--space-2:  .5rem;
--space-3:  .75rem;
--space-4:  1rem;
--space-5:  1.25rem;
--space-6:  1.5rem;
--space-8:  2rem;
--space-10: 2.5rem;
--space-12: 3rem;
--space-16: 4rem;
--space-20: 5rem;
--space-24: 6rem; --container-sm:  640px;
--container-md:  768px;
--container-lg:  1024px;
--container-xl:  1280px;
--container-2xl: 1440px; --radius-sm:   4px;
--radius-md:   8px;
--radius-lg:   12px;
--radius-xl:   20px;
--radius-full: 9999px; --shadow-sm:  0 1px 3px rgba(16,24,32,.08), 0 1px 2px rgba(16,24,32,.06);
--shadow-md:  0 4px 16px rgba(16,24,32,.1);
--shadow-lg:  0 12px 40px rgba(16,24,32,.12);
--shadow-xl:  0 24px 64px rgba(16,24,32,.16); --transition-fast:   150ms ease;
--transition-normal: 250ms ease;
--transition-slow:   400ms ease; --z-base:    0;
--z-raised:  10;
--z-overlay: 100;
--z-modal:   200;
--z-toast:   300;
--z-nav:     400;
} *, *::before, *::after {
box-sizing: border-box;
}
html {
font-size: 100%;
scroll-behavior: smooth;
-webkit-text-size-adjust: 100%;
text-size-adjust: 100%;
}
body {
margin: 0;
font-family: var(--font-primary);
font-size: var(--text-base);
line-height: var(--leading-normal);
color: var(--color-text);
background-color: var(--color-bg);
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
} h1, h2, h3, h4, h5, h6 {
margin: 0 0 var(--space-4);
font-family: var(--font-primary);
font-weight: 700;
line-height: var(--leading-tight);
color: var(--color-navy);
}
p { margin: 0 0 var(--space-4); }
p:last-child { margin-bottom: 0; }
ul, ol { margin: 0 0 var(--space-4); padding-left: var(--space-6); }
li { margin-bottom: var(--space-2); }
a {
color: var(--color-blue);
text-decoration: underline;
text-underline-offset: 3px;
transition: color var(--transition-fast), opacity var(--transition-fast);
}
a:hover { color: var(--color-violet); }
a:focus-visible {
outline: 3px solid var(--color-blue);
outline-offset: 3px;
border-radius: var(--radius-sm);
}
img, svg, video {
display: block;
max-width: 100%;
height: auto;
}
figure { margin: 0; }
button {
cursor: pointer;
font-family: var(--font-primary);
border: none;
background: none;
}
input, textarea, select {
font-family: var(--font-primary);
font-size: var(--text-base);
} h1 { font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl)); }
h2 { font-size: clamp(var(--text-2xl), 3.5vw, var(--text-4xl)); }
h3 { font-size: clamp(var(--text-xl), 2.5vw, var(--text-3xl)); }
h4 { font-size: var(--text-xl); }
h5 { font-size: var(--text-lg); }
h6 { font-size: var(--text-base); } .container {
width: 100%;
max-width: var(--container-xl);
margin-inline: auto;
padding-inline: var(--space-6);
}
.container--sm  { max-width: var(--container-sm); }
.container--md  { max-width: var(--container-md); }
.container--lg  { max-width: var(--container-lg); }
.container--2xl { max-width: var(--container-2xl); }
.site-wrapper {
display: flex;
flex-direction: column;
min-height: 100dvh;
}
.site-main {
flex: 1;
} .skip-link {
position: absolute;
top: -100%;
left: var(--space-4);
z-index: var(--z-toast);
padding: var(--space-3) var(--space-6);
background: var(--color-navy);
color: var(--color-white) !important;
text-decoration: none;
border-radius: var(--radius-md);
font-weight: 600;
font-size: var(--text-sm);
transition: top var(--transition-fast);
}
.skip-link:focus {
top: var(--space-4);
outline: 3px solid var(--color-blue);
outline-offset: 3px;
} .site-header {
position: sticky;
top: 0;
z-index: var(--z-nav);
background: var(--color-white);
border-bottom: 1px solid var(--color-border);
box-shadow: var(--shadow-sm);
}
.site-header__inner {
display: flex;
align-items: center;
justify-content: space-between;
gap: var(--space-6);
padding-block: var(--space-4);
} .site-logo {
display: flex;
align-items: center;
text-decoration: none;
flex-shrink: 0;
}
.site-logo img {
height: 40px;
width: auto;
}
.site-logo__text {
font-family: var(--font-logo);
font-size: var(--text-2xl);
font-weight: 700;
color: var(--color-navy);
text-decoration: none;
letter-spacing: -.03em;
} .primary-nav { display: flex; align-items: center; }
.primary-nav ul {
display: flex;
align-items: center;
gap: var(--space-1);
list-style: none;
margin: 0;
padding: 0;
}
.primary-nav a {
display: block;
padding: var(--space-2) var(--space-4);
color: var(--color-text);
text-decoration: none;
font-weight: 500;
font-size: var(--text-sm);
border-radius: var(--radius-md);
transition: background var(--transition-fast), color var(--transition-fast);
}
.primary-nav a:hover,
.primary-nav .current-menu-item > a,
.primary-nav .current-menu-ancestor > a {
background: var(--color-surface);
color: var(--color-navy);
} .nav-toggle {
display: none;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
border-radius: var(--radius-md);
border: 1.5px solid var(--color-border);
background: transparent;
color: var(--color-text);
}
.nav-toggle:hover { background: var(--color-surface); }
.nav-toggle[aria-expanded="true"] .icon-burger { display: none; }
.nav-toggle[aria-expanded="false"] .icon-close  { display: none; } .site-footer {
background: var(--color-navy);
color: rgba(255,255,255,.75);
padding-block: var(--space-12) var(--space-8);
}
.site-footer__grid {
display: grid;
grid-template-columns: 2fr 1fr 1fr 1fr;
gap: var(--space-8);
margin-bottom: var(--space-8);
}
.site-footer__brand .site-logo__text { color: var(--color-white); }
.site-footer__brand p {
font-size: var(--text-sm);
margin-top: var(--space-4);
color: rgba(255,255,255,.6);
}
.footer-nav h3,
.footer-widget h3 {
color: var(--color-white);
font-size: var(--text-sm);
font-weight: 700;
text-transform: uppercase;
letter-spacing: .08em;
margin-bottom: var(--space-4);
}
.footer-nav ul,
.footer-widget ul {
list-style: none;
padding: 0;
margin: 0;
}
.footer-nav li,
.footer-widget li { margin-bottom: var(--space-2); }
.footer-nav a,
.footer-widget a {
color: rgba(255,255,255,.65);
text-decoration: none;
font-size: var(--text-sm);
transition: color var(--transition-fast);
}
.footer-nav a:hover,
.footer-widget a:hover { color: var(--color-white); }
.site-footer__bottom {
display: flex;
align-items: center;
justify-content: space-between;
gap: var(--space-4);
padding-top: var(--space-6);
border-top: 1px solid rgba(255,255,255,.1);
font-size: var(--text-xs);
color: rgba(255,255,255,.4);
}
.footer-social {
display: flex;
gap: var(--space-3);
}
.footer-social a {
display: flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
border-radius: var(--radius-full);
background: rgba(255,255,255,.1);
color: rgba(255,255,255,.7);
text-decoration: none;
transition: background var(--transition-fast), color var(--transition-fast);
}
.footer-social a:hover {
background: var(--color-blue);
color: var(--color-white);
} .btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: var(--space-2);
padding: var(--space-3) var(--space-6);
font-family: var(--font-primary);
font-size: var(--text-sm);
font-weight: 600;
line-height: 1;
text-decoration: none;
border-radius: var(--radius-md);
border: 2px solid transparent;
cursor: pointer;
transition: all var(--transition-fast);
white-space: nowrap;
}
.btn:focus-visible {
outline: 3px solid var(--color-blue);
outline-offset: 3px;
}
.btn--primary {
background: var(--color-blue);
color: var(--color-white);
border-color: var(--color-blue);
}
.btn--primary:hover {
background: var(--color-violet);
border-color: var(--color-violet);
color: var(--color-white);
}
.btn--secondary {
background: transparent;
color: var(--color-navy);
border-color: var(--color-navy);
}
.btn--secondary:hover {
background: var(--color-navy);
color: var(--color-white);
}
.btn--ghost {
background: transparent;
color: var(--color-blue);
border-color: transparent;
}
.btn--ghost:hover {
background: rgba(16,0,240,.06);
}
.btn--lg {
padding: var(--space-4) var(--space-8);
font-size: var(--text-base);
border-radius: var(--radius-lg);
}
.btn--sm {
padding: var(--space-2) var(--space-4);
font-size: var(--text-xs);
} .card {
background: var(--color-white);
border: 1px solid var(--color-border);
border-radius: var(--radius-lg);
overflow: hidden;
transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}
.card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-2px);
}
.card__image { aspect-ratio: 16/9; overflow: hidden; }
.card__image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform var(--transition-slow);
}
.card:hover .card__image img { transform: scale(1.04); }
.card__body { padding: var(--space-6); }
.card__title {
font-size: var(--text-lg);
margin-bottom: var(--space-3);
color: var(--color-navy);
}
.card__excerpt {
font-size: var(--text-sm);
color: var(--color-text-muted);
margin-bottom: var(--space-4);
} .entry-header { margin-bottom: var(--space-8); }
.entry-title {
font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
color: var(--color-navy);
margin-bottom: var(--space-4);
}
.entry-meta {
display: flex;
flex-wrap: wrap;
gap: var(--space-4);
font-size: var(--text-sm);
color: var(--color-text-muted);
margin-bottom: var(--space-6);
}
.entry-meta a { color: var(--color-blue); }
.entry-content {
font-size: var(--text-lg);
line-height: var(--leading-loose);
max-width: 72ch;
}
.entry-content h2,
.entry-content h3,
.entry-content h4 {
margin-top: var(--space-10);
margin-bottom: var(--space-4);
}
.entry-content img {
border-radius: var(--radius-lg);
margin-block: var(--space-8);
}
.entry-content blockquote {
border-left: 4px solid var(--color-blue);
padding-left: var(--space-6);
margin-inline: 0;
margin-block: var(--space-8);
font-style: italic;
font-size: var(--text-xl);
color: var(--color-navy);
}
.entry-content code {
background: var(--color-surface);
padding: var(--space-1) var(--space-2);
border-radius: var(--radius-sm);
font-family: var(--font-mono);
font-size: .875em;
}
.entry-content pre {
background: var(--color-black);
color: #e2e8f0;
padding: var(--space-6);
border-radius: var(--radius-lg);
overflow-x: auto;
margin-block: var(--space-6);
}
.entry-content pre code {
background: none;
padding: 0;
font-size: var(--text-sm);
color: inherit;
} .pagination {
display: flex;
align-items: center;
justify-content: center;
gap: var(--space-2);
margin-top: var(--space-12);
flex-wrap: wrap;
}
.pagination a,
.pagination span {
display: flex;
align-items: center;
justify-content: center;
min-width: 40px;
height: 40px;
padding: 0 var(--space-3);
border-radius: var(--radius-md);
font-size: var(--text-sm);
font-weight: 500;
text-decoration: none;
border: 1.5px solid var(--color-border);
transition: all var(--transition-fast);
}
.pagination a:hover { border-color: var(--color-blue); color: var(--color-blue); }
.pagination .current {
background: var(--color-navy);
border-color: var(--color-navy);
color: var(--color-white);
} .form-group { margin-bottom: var(--space-6); }
.form-label {
display: block;
font-size: var(--text-sm);
font-weight: 600;
margin-bottom: var(--space-2);
color: var(--color-text);
}
.form-control {
width: 100%;
padding: var(--space-3) var(--space-4);
border: 2px solid var(--color-border);
border-radius: var(--radius-md);
font-family: var(--font-primary);
font-size: var(--text-base);
color: var(--color-text);
background: var(--color-white);
transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
appearance: none;
}
.form-control:focus {
outline: none;
border-color: var(--color-blue);
box-shadow: 0 0 0 3px rgba(16,0,240,.12);
}  .sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0,0,0,0);
white-space: nowrap;
border-width: 0;
} :focus-visible {
outline: 3px solid var(--color-blue);
outline-offset: 3px;
} @media (prefers-reduced-motion: reduce) {
*, *::before, *::after {
animation-duration: .01ms !important;
animation-iteration-count: 1 !important;
transition-duration: .01ms !important;
scroll-behavior: auto !important;
}
} @media (prefers-color-scheme: dark) {
:root {
--color-bg:         #0f0e1a;
--color-surface:    #1a1830;
--color-border:     #2d2b45;
--color-text:       #e8e8f0;
--color-text-muted: #9090a8;
--color-white:      #1a1830;
--color-black:      #e8e8f0;
}
.site-header { background: #0f0e1a; }
.card { background: #1a1830; }
} .lsf-video-wrapper {
position: relative;
display: inline-block;
}
.lsf-trigger {
display: flex;
align-items: center;
gap: var(--space-2);
padding: var(--space-2) var(--space-4);
background: var(--color-navy);
color: var(--color-white);
border-radius: var(--radius-full);
font-size: var(--text-sm);
font-weight: 600;
cursor: pointer;
border: none;
transition: background var(--transition-fast);
}
.lsf-trigger:hover { background: var(--color-blue); }
.lsf-video-overlay {
position: fixed;
bottom: var(--space-6);
right: var(--space-6);
z-index: var(--z-modal);
background: var(--color-navy);
border-radius: var(--radius-xl);
overflow: hidden;
box-shadow: var(--shadow-xl);
max-width: 320px;
display: none;
}
.lsf-video-overlay.is-visible { display: block; }
.lsf-video-overlay video {
width: 100%;
display: block;
}
.lsf-close {
position: absolute;
top: var(--space-2);
right: var(--space-2);
width: 32px;
height: 32px;
background: rgba(255,255,255,.2);
border-radius: var(--radius-full);
display: flex;
align-items: center;
justify-content: center;
color: var(--color-white);
cursor: pointer;
border: none;
font-size: 1.2rem;
line-height: 1;
} .wp-block-image img { border-radius: var(--radius-lg); }
.wp-block-quote {
border-left: 4px solid var(--color-blue);
padding-left: var(--space-6);
margin-inline: 0;
}
.wp-block-button .wp-block-button__link {
border-radius: var(--radius-md) !important;
font-family: var(--font-primary);
font-weight: 600;
}
.wp-block-cover { border-radius: var(--radius-xl); }
.wp-block-separator { border-color: var(--color-border); }
.alignfull { margin-inline: calc(50% - 50vw); max-width: 100vw; }
.alignwide { max-width: var(--container-2xl); margin-inline: auto; } .text-center  { text-align: center; }
.text-left    { text-align: left; }
.text-right   { text-align: right; }
.text-navy    { color: var(--color-navy); }
.text-blue    { color: var(--color-blue); }
.text-muted   { color: var(--color-text-muted); }
.text-white   { color: var(--color-white); }
.bg-navy    { background-color: var(--color-navy); }
.bg-blue    { background-color: var(--color-blue); }
.bg-surface { background-color: var(--color-surface); }
.bg-pink    { background-color: var(--color-pink); }
.mt-0  { margin-top: 0; }
.mb-0  { margin-bottom: 0; }
.mt-4  { margin-top: var(--space-4); }
.mb-4  { margin-bottom: var(--space-4); }
.mt-8  { margin-top: var(--space-8); }
.mb-8  { margin-bottom: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }
.mb-12 { margin-bottom: var(--space-12); }
.hidden    { display: none; }
.invisible { visibility: hidden; } @media (max-width: 1024px) {
.site-footer__grid {
grid-template-columns: 1fr 1fr;
}
}
@media (max-width: 768px) {
.nav-toggle { display: flex; }
.primary-nav {
position: fixed;
inset: 0;
background: var(--color-white);
z-index: var(--z-nav);
flex-direction: column;
align-items: stretch;
justify-content: flex-start;
padding: var(--space-20) var(--space-6) var(--space-6);
transform: translateX(-100%);
transition: transform var(--transition-normal);
}
.primary-nav.is-open { transform: translateX(0); }
.primary-nav ul {
flex-direction: column;
align-items: stretch;
gap: 0;
}
.primary-nav a {
padding: var(--space-4);
font-size: var(--text-base);
border-radius: var(--radius-md);
}
.site-footer__grid { grid-template-columns: 1fr; }
.site-footer__bottom { flex-direction: column; text-align: center; }
}
@media (max-width: 480px) {
:root {
--space-6: 1rem;
}
.container { padding-inline: var(--space-4); }
}