/*
Theme Name: Aegis
Theme URI: https://example.com/themes/aegis
Author: Bond Master
Author URI: https://example.com
Description: Aegis is a premium cybersecurity, IT security, and managed-security-services (MSSP) WordPress theme. Built for SOCs, penetration-testing firms, threat-intelligence vendors, VPN providers, and security consultancies. Includes a sectioned front page (hero, services, features, threat-stats, pricing, testimonials, CTA, partners), custom menus, a Customizer-driven header, ready-made page templates (About, Services, Pricing, Contact), full blog support, translation-ready strings, and a dark "command-center" aesthetic. Marketplace-ready and GPL-licensed.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aegis
Tags: dark, two-columns, right-sidebar, custom-logo, custom-menu, custom-colors, custom-header, featured-images, blog, business, technology, full-width-template, translation-ready, threaded-comments, footer-widgets, sticky-post
*/

/* =========================================================================
   AEGIS — Design Tokens
   ========================================================================= */
:root {
    /* Core palette — "command center" dark */
    --aegis-bg:            #070b18;
    --aegis-bg-alt:        #0a1024;
    --aegis-surface:       #0e152e;
    --aegis-surface-2:     #131b38;
    --aegis-line:          rgba(120, 160, 220, 0.14);
    --aegis-line-strong:   rgba(120, 160, 220, 0.28);

    /* Accents */
    --aegis-cyan:          #22d3ee;
    --aegis-cyan-dim:      #0e7490;
    --aegis-green:         #4ade80;  /* "secure" status */
    --aegis-amber:         #fbbf24;  /* "warning" status */
    --aegis-red:           #f87171;  /* "threat" status */
    --aegis-glow:          rgba(34, 211, 238, 0.45);

    /* Text */
    --aegis-text:          #e6ecf7;
    --aegis-text-soft:     #9fb0cc;
    --aegis-text-dim:      #6b7a99;

    /* Typography */
    --aegis-font-display:  "Chakra Petch", "Segoe UI", sans-serif;
    --aegis-font-body:     "Manrope", -apple-system, BlinkMacSystemFont, sans-serif;
    --aegis-font-mono:     "JetBrains Mono", "SFMono-Regular", Consolas, monospace;

    /* Geometry */
    --aegis-radius:        14px;
    --aegis-radius-sm:     8px;
    --aegis-container:     1200px;
    --aegis-gutter:        clamp(1.25rem, 4vw, 3rem);
    --aegis-section-y:     clamp(4rem, 9vw, 8rem);

    /* Effects */
    --aegis-shadow:        0 24px 60px -28px rgba(0, 0, 0, 0.85);
    --aegis-ease:          cubic-bezier(0.2, 0.7, 0.2, 1);
}

/* =========================================================================
   Reset / Base
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    font-family: var(--aegis-font-body);
    font-size: 1.0625rem;
    line-height: 1.7;
    color: var(--aegis-text);
    background-color: var(--aegis-bg);
    background-image:
        radial-gradient(1200px 600px at 80% -10%, rgba(34, 211, 238, 0.10), transparent 60%),
        radial-gradient(900px 500px at -10% 10%, rgba(74, 222, 128, 0.06), transparent 55%),
        linear-gradient(transparent 0 95%, rgba(120, 160, 220, 0.05) 100%),
        linear-gradient(90deg, transparent 0 95%, rgba(120, 160, 220, 0.05) 100%);
    background-size: auto, auto, 44px 44px, 44px 44px;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--aegis-cyan); text-decoration: none; transition: color 0.2s var(--aegis-ease); }
a:hover { color: #67e8f9; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--aegis-font-display);
    font-weight: 600;
    line-height: 1.12;
    letter-spacing: -0.01em;
    margin: 0 0 0.6em;
    color: var(--aegis-text);
}

h1 { font-size: clamp(2.4rem, 5.5vw, 4rem); }
h2 { font-size: clamp(1.9rem, 3.8vw, 2.85rem); }
h3 { font-size: clamp(1.35rem, 2.2vw, 1.7rem); }

p { margin: 0 0 1.2em; }

ul, ol { padding-left: 1.25rem; }

blockquote {
    margin: 1.8rem 0;
    padding: 1rem 1.5rem;
    border-left: 3px solid var(--aegis-cyan);
    background: var(--aegis-surface);
    border-radius: 0 var(--aegis-radius-sm) var(--aegis-radius-sm) 0;
    color: var(--aegis-text-soft);
    font-style: italic;
}

code, pre, kbd {
    font-family: var(--aegis-font-mono);
    font-size: 0.9em;
}

pre {
    background: #05080f;
    border: 1px solid var(--aegis-line);
    border-radius: var(--aegis-radius-sm);
    padding: 1.25rem;
    overflow-x: auto;
}

code { color: var(--aegis-cyan); }

:focus-visible { outline: 2px solid var(--aegis-cyan); outline-offset: 3px; }

/* =========================================================================
   Layout helpers
   ========================================================================= */
.aegis-container {
    width: 100%;
    max-width: var(--aegis-container);
    margin-inline: auto;
    padding-inline: var(--aegis-gutter);
}

.aegis-section { padding-block: var(--aegis-section-y); position: relative; }
.aegis-section--alt { background: var(--aegis-bg-alt); }

.aegis-section-head {
    max-width: 680px;
    margin: 0 auto clamp(2.5rem, 5vw, 4rem);
    text-align: center;
}

.aegis-eyebrow {
    font-family: var(--aegis-font-mono);
    font-size: 0.78rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--aegis-cyan);
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 1rem;
}
.aegis-eyebrow::before {
    content: "";
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--aegis-green);
    box-shadow: 0 0 0 4px rgba(74, 222, 128, 0.18);
    animation: aegis-pulse 2.4s var(--aegis-ease) infinite;
}

@keyframes aegis-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: 0.5; transform: scale(0.82); }
}

.aegis-lead { color: var(--aegis-text-soft); font-size: 1.1rem; }

/* Buttons */
.aegis-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-family: var(--aegis-font-display);
    font-weight: 600;
    font-size: 0.98rem;
    letter-spacing: 0.01em;
    padding: 0.85rem 1.7rem;
    border-radius: var(--aegis-radius-sm);
    border: 1px solid transparent;
    cursor: pointer;
    transition: transform 0.2s var(--aegis-ease), box-shadow 0.2s var(--aegis-ease), background 0.2s var(--aegis-ease);
    text-align: center;
}
.aegis-btn--primary {
    background: linear-gradient(135deg, var(--aegis-cyan), #0891b2);
    color: #04121a;
    box-shadow: 0 0 0 1px rgba(34, 211, 238, 0.4), 0 14px 30px -12px var(--aegis-glow);
}
.aegis-btn--primary:hover { transform: translateY(-2px); color: #04121a; box-shadow: 0 0 0 1px rgba(34, 211, 238, 0.6), 0 20px 40px -12px var(--aegis-glow); }
.aegis-btn--ghost {
    background: rgba(120, 160, 220, 0.06);
    border-color: var(--aegis-line-strong);
    color: var(--aegis-text);
}
.aegis-btn--ghost:hover { border-color: var(--aegis-cyan); color: var(--aegis-cyan); transform: translateY(-2px); }

/* =========================================================================
   Header / Navigation
   ========================================================================= */
.aegis-topbar {
    background: #04070f;
    border-bottom: 1px solid var(--aegis-line);
    font-family: var(--aegis-font-mono);
    font-size: 0.78rem;
    color: var(--aegis-text-dim);
}
.aegis-topbar .aegis-container {
    display: flex; align-items: center; justify-content: space-between;
    min-height: 38px; gap: 1rem; flex-wrap: wrap;
}
.aegis-topbar a { color: var(--aegis-text-soft); }
.aegis-topbar-status { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--aegis-green); }
.aegis-topbar-status::before {
    content: ""; width: 7px; height: 7px; border-radius: 50%;
    background: var(--aegis-green); box-shadow: 0 0 8px var(--aegis-green);
}
.aegis-topbar-meta { display: inline-flex; gap: 1.4rem; flex-wrap: wrap; }

.aegis-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(7, 11, 24, 0.82);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--aegis-line);
    transition: box-shadow 0.3s var(--aegis-ease), background 0.3s var(--aegis-ease);
}
.aegis-header.is-stuck { box-shadow: var(--aegis-shadow); background: rgba(7, 11, 24, 0.95); }
.aegis-header .aegis-container {
    display: flex; align-items: center; justify-content: space-between;
    min-height: 78px; gap: 1.5rem;
}

.aegis-brand { display: flex; align-items: center; gap: 0.75rem; }
.aegis-brand img { max-height: 46px; width: auto; }
.aegis-brand-text { display: flex; flex-direction: column; line-height: 1; }
.aegis-site-title {
    font-family: var(--aegis-font-display);
    font-weight: 700; font-size: 1.5rem; letter-spacing: 0.02em;
    color: var(--aegis-text); margin: 0;
}
.aegis-site-title a { color: inherit; }
.aegis-site-title .aegis-dot { color: var(--aegis-cyan); }
.aegis-site-desc {
    font-family: var(--aegis-font-mono);
    font-size: 0.66rem; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--aegis-text-dim); margin-top: 0.35rem;
}

/* Primary menu */
.aegis-nav { display: flex; align-items: center; gap: 2rem; }
.aegis-menu { list-style: none; display: flex; gap: 0.35rem; margin: 0; padding: 0; }
.aegis-menu li { position: relative; }
.aegis-menu a {
    display: block; padding: 0.6rem 0.95rem; border-radius: var(--aegis-radius-sm);
    font-family: var(--aegis-font-display); font-weight: 500; font-size: 0.97rem;
    color: var(--aegis-text-soft);
}
.aegis-menu a:hover,
.aegis-menu .current-menu-item > a,
.aegis-menu .current_page_item > a {
    color: var(--aegis-text); background: rgba(120, 160, 220, 0.08);
}
.aegis-menu .menu-item-has-children > a::after {
    content: "▾"; font-size: 0.7em; margin-left: 0.4rem; color: var(--aegis-cyan);
}
/* Sub-menus */
.aegis-menu ul.sub-menu {
    position: absolute; top: calc(100% + 10px); left: 0;
    min-width: 220px; list-style: none; margin: 0; padding: 0.5rem;
    background: var(--aegis-surface);
    border: 1px solid var(--aegis-line-strong);
    border-radius: var(--aegis-radius); box-shadow: var(--aegis-shadow);
    opacity: 0; visibility: hidden; transform: translateY(8px);
    transition: all 0.22s var(--aegis-ease); z-index: 50;
}
.aegis-menu li:hover > ul.sub-menu,
.aegis-menu li:focus-within > ul.sub-menu {
    opacity: 1; visibility: visible; transform: translateY(0);
}
.aegis-menu ul.sub-menu a { font-size: 0.92rem; }

.aegis-header-cta { display: flex; align-items: center; gap: 0.75rem; }

/* Mobile toggle */
.aegis-nav-toggle {
    display: none; width: 46px; height: 46px;
    background: var(--aegis-surface); border: 1px solid var(--aegis-line-strong);
    border-radius: var(--aegis-radius-sm); cursor: pointer; padding: 0;
    align-items: center; justify-content: center;
}
.aegis-nav-toggle span,
.aegis-nav-toggle span::before,
.aegis-nav-toggle span::after {
    content: ""; display: block; width: 20px; height: 2px;
    background: var(--aegis-text); border-radius: 2px; position: relative;
    transition: transform 0.25s var(--aegis-ease), opacity 0.25s var(--aegis-ease);
}
.aegis-nav-toggle span::before { position: absolute; top: -6px; }
.aegis-nav-toggle span::after  { position: absolute; top: 6px; }
.aegis-nav-toggle[aria-expanded="true"] span { background: transparent; }
.aegis-nav-toggle[aria-expanded="true"] span::before { transform: translateY(6px) rotate(45deg); }
.aegis-nav-toggle[aria-expanded="true"] span::after  { transform: translateY(-6px) rotate(-45deg); }

/* =========================================================================
   Hero
   ========================================================================= */
.aegis-hero { position: relative; padding-block: clamp(4rem, 10vw, 8rem); overflow: hidden; }
.aegis-hero::before {
    content: ""; position: absolute; inset: 0;
    background:
        radial-gradient(700px 400px at 75% 30%, rgba(34, 211, 238, 0.14), transparent 60%);
    pointer-events: none;
}
.aegis-hero-grid {
    display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2rem, 5vw, 4.5rem);
    align-items: center; position: relative; z-index: 2;
}
.aegis-hero h1 { margin-bottom: 1.1rem; }
.aegis-hero h1 .aegis-hl {
    background: linear-gradient(120deg, var(--aegis-cyan), var(--aegis-green));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.aegis-hero-lead { font-size: 1.2rem; color: var(--aegis-text-soft); max-width: 46ch; }
.aegis-hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2rem; }
.aegis-hero-trust {
    display: flex; gap: 2rem; margin-top: 2.5rem; flex-wrap: wrap;
    font-family: var(--aegis-font-mono); font-size: 0.8rem; color: var(--aegis-text-dim);
}
.aegis-hero-trust strong { display: block; font-family: var(--aegis-font-display); font-size: 1.6rem; color: var(--aegis-text); }

/* Hero terminal card */
.aegis-terminal {
    background: linear-gradient(180deg, var(--aegis-surface), var(--aegis-bg-alt));
    border: 1px solid var(--aegis-line-strong);
    border-radius: var(--aegis-radius); box-shadow: var(--aegis-shadow);
    overflow: hidden; font-family: var(--aegis-font-mono); font-size: 0.86rem;
}
.aegis-terminal-bar {
    display: flex; align-items: center; gap: 0.5rem;
    padding: 0.8rem 1rem; border-bottom: 1px solid var(--aegis-line);
    background: #05080f;
}
.aegis-terminal-bar i { width: 11px; height: 11px; border-radius: 50%; display: inline-block; }
.aegis-terminal-bar i:nth-child(1) { background: var(--aegis-red); }
.aegis-terminal-bar i:nth-child(2) { background: var(--aegis-amber); }
.aegis-terminal-bar i:nth-child(3) { background: var(--aegis-green); }
.aegis-terminal-bar span { margin-left: 0.6rem; color: var(--aegis-text-dim); font-size: 0.78rem; }
.aegis-terminal-body { padding: 1.25rem 1.4rem; line-height: 1.95; }
.aegis-terminal-body .t-prompt { color: var(--aegis-cyan); }
.aegis-terminal-body .t-ok { color: var(--aegis-green); }
.aegis-terminal-body .t-warn { color: var(--aegis-amber); }
.aegis-terminal-body .t-dim { color: var(--aegis-text-dim); }
.aegis-cursor { display: inline-block; width: 9px; height: 1.05em; background: var(--aegis-cyan); vertical-align: text-bottom; animation: aegis-blink 1.1s steps(2) infinite; }
@keyframes aegis-blink { 50% { opacity: 0; } }

/* =========================================================================
   Cards / Grids
   ========================================================================= */
.aegis-grid { display: grid; gap: 1.5rem; }
.aegis-grid--3 { grid-template-columns: repeat(3, 1fr); }
.aegis-grid--4 { grid-template-columns: repeat(4, 1fr); }
.aegis-grid--2 { grid-template-columns: repeat(2, 1fr); }

.aegis-card {
    background: linear-gradient(180deg, var(--aegis-surface), var(--aegis-bg-alt));
    border: 1px solid var(--aegis-line);
    border-radius: var(--aegis-radius); padding: 2rem;
    transition: transform 0.3s var(--aegis-ease), border-color 0.3s var(--aegis-ease);
    position: relative; overflow: hidden;
}
.aegis-card::after {
    content: ""; position: absolute; inset: 0; border-radius: inherit;
    background: linear-gradient(120deg, transparent, rgba(34, 211, 238, 0.06));
    opacity: 0; transition: opacity 0.3s var(--aegis-ease);
}
.aegis-card:hover { transform: translateY(-6px); border-color: var(--aegis-line-strong); }
.aegis-card:hover::after { opacity: 1; }
.aegis-card-icon {
    width: 52px; height: 52px; border-radius: var(--aegis-radius-sm);
    display: grid; place-items: center; margin-bottom: 1.25rem;
    background: rgba(34, 211, 238, 0.1); border: 1px solid rgba(34, 211, 238, 0.25);
    color: var(--aegis-cyan); font-size: 1.5rem;
}
.aegis-card h3 { font-size: 1.3rem; margin-bottom: 0.6rem; }
.aegis-card p { color: var(--aegis-text-soft); font-size: 0.98rem; margin: 0; }

/* Stats */
.aegis-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.aegis-stat { text-align: center; padding: 1.5rem 1rem; border: 1px solid var(--aegis-line); border-radius: var(--aegis-radius); background: var(--aegis-surface); }
.aegis-stat-num { font-family: var(--aegis-font-display); font-size: clamp(2.2rem, 4vw, 3rem); color: var(--aegis-cyan); line-height: 1; }
.aegis-stat-label { font-family: var(--aegis-font-mono); font-size: 0.75rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--aegis-text-dim); margin-top: 0.7rem; }

/* Feature split */
.aegis-feature-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.aegis-feature-list { list-style: none; padding: 0; margin: 1.5rem 0 0; display: grid; gap: 1rem; }
.aegis-feature-list li { display: flex; gap: 0.85rem; align-items: flex-start; color: var(--aegis-text-soft); }
.aegis-feature-list li::before {
    content: "✓"; flex: 0 0 24px; height: 24px; border-radius: 50%;
    display: grid; place-items: center; font-size: 0.8rem; font-weight: 700;
    color: var(--aegis-green); background: rgba(74, 222, 128, 0.12); border: 1px solid rgba(74, 222, 128, 0.3);
}

/* Pricing */
.aegis-pricing { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.aegis-price-card {
    background: var(--aegis-surface); border: 1px solid var(--aegis-line);
    border-radius: var(--aegis-radius); padding: 2.25rem; position: relative;
    transition: transform 0.3s var(--aegis-ease), border-color 0.3s var(--aegis-ease);
}
.aegis-price-card:hover { transform: translateY(-6px); }
.aegis-price-card.is-featured { border-color: var(--aegis-cyan); box-shadow: 0 0 0 1px var(--aegis-cyan), 0 30px 60px -30px var(--aegis-glow); }
.aegis-price-badge {
    position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
    font-family: var(--aegis-font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase;
    background: linear-gradient(135deg, var(--aegis-cyan), #0891b2); color: #04121a;
    padding: 0.35rem 0.9rem; border-radius: 99px; font-weight: 700;
}
.aegis-price-name { font-family: var(--aegis-font-mono); font-size: 0.82rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--aegis-cyan); }
.aegis-price-amount { font-family: var(--aegis-font-display); font-size: 3rem; line-height: 1; margin: 0.8rem 0 0.2rem; }
.aegis-price-amount small { font-family: var(--aegis-font-mono); font-size: 0.9rem; color: var(--aegis-text-dim); }
.aegis-price-list { list-style: none; padding: 0; margin: 1.5rem 0; display: grid; gap: 0.75rem; }
.aegis-price-list li { display: flex; gap: 0.6rem; color: var(--aegis-text-soft); font-size: 0.95rem; }
.aegis-price-list li::before { content: "›"; color: var(--aegis-cyan); font-weight: 700; }

/* Testimonials */
.aegis-quote { background: var(--aegis-surface); border: 1px solid var(--aegis-line); border-radius: var(--aegis-radius); padding: 2rem; }
.aegis-quote-text { font-size: 1.05rem; color: var(--aegis-text); margin-bottom: 1.5rem; }
.aegis-quote-author { display: flex; align-items: center; gap: 0.85rem; }
.aegis-quote-avatar { width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(135deg, var(--aegis-cyan), var(--aegis-green)); display: grid; place-items: center; font-family: var(--aegis-font-display); font-weight: 700; color: #04121a; }
.aegis-quote-name { font-family: var(--aegis-font-display); font-weight: 600; }
.aegis-quote-role { font-size: 0.82rem; color: var(--aegis-text-dim); font-family: var(--aegis-font-mono); }

/* CTA */
.aegis-cta-band {
    border: 1px solid var(--aegis-line-strong); border-radius: calc(var(--aegis-radius) * 1.6);
    padding: clamp(2.5rem, 6vw, 4.5rem); text-align: center;
    background:
        radial-gradient(600px 300px at 50% 0%, rgba(34, 211, 238, 0.16), transparent 65%),
        linear-gradient(180deg, var(--aegis-surface), var(--aegis-bg-alt));
    position: relative; overflow: hidden;
}
.aegis-cta-band h2 { max-width: 18ch; margin-inline: auto; }
.aegis-cta-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-top: 1.8rem; }

/* Partners / logos */
.aegis-partners { display: flex; flex-wrap: wrap; gap: 2.5rem 3.5rem; justify-content: center; align-items: center; }
.aegis-partner { font-family: var(--aegis-font-display); font-weight: 700; font-size: 1.3rem; color: var(--aegis-text-dim); letter-spacing: 0.02em; opacity: 0.7; transition: opacity 0.25s, color 0.25s; }
.aegis-partner:hover { opacity: 1; color: var(--aegis-text); }

/* =========================================================================
   Blog / Content
   ========================================================================= */
.aegis-content-wrap { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: clamp(2rem, 4vw, 3.5rem); padding-block: var(--aegis-section-y); }
.aegis-content-wrap.is-full { grid-template-columns: minmax(0, 1fr); max-width: 820px; }

.aegis-post-card {
    background: var(--aegis-surface); border: 1px solid var(--aegis-line);
    border-radius: var(--aegis-radius); overflow: hidden; margin-bottom: 2rem;
    transition: transform 0.3s var(--aegis-ease), border-color 0.3s var(--aegis-ease);
}
.aegis-post-card:hover { transform: translateY(-4px); border-color: var(--aegis-line-strong); }
.aegis-post-thumb img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; }
.aegis-post-body { padding: 1.75rem; }
.aegis-post-meta { font-family: var(--aegis-font-mono); font-size: 0.76rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--aegis-text-dim); margin-bottom: 0.75rem; display: flex; gap: 1rem; flex-wrap: wrap; }
.aegis-post-meta a { color: var(--aegis-cyan); }
.aegis-post-title { font-size: 1.5rem; margin-bottom: 0.6rem; }
.aegis-post-title a { color: var(--aegis-text); }
.aegis-post-title a:hover { color: var(--aegis-cyan); }
.aegis-post-excerpt { color: var(--aegis-text-soft); }
.aegis-readmore { font-family: var(--aegis-font-display); font-weight: 600; display: inline-flex; gap: 0.4rem; margin-top: 0.5rem; }

.aegis-entry-content { font-size: 1.08rem; }
.aegis-entry-content > * { margin-bottom: 1.3em; }
.aegis-entry-content h2, .aegis-entry-content h3 { margin-top: 1.8em; }
.aegis-entry-content img { border-radius: var(--aegis-radius-sm); }
.aegis-entry-content a { text-decoration: underline; text-underline-offset: 3px; }

.wp-caption { max-width: 100%; }
.wp-caption-text, .gallery-caption { font-size: 0.85rem; color: var(--aegis-text-dim); text-align: center; }
.alignleft { float: left; margin: 0.4rem 1.5rem 1rem 0; }
.alignright { float: right; margin: 0.4rem 0 1rem 1.5rem; }
.aligncenter { margin-inline: auto; }
.sticky .aegis-post-card { border-color: var(--aegis-cyan); }
.bypostauthor { display: block; }

.aegis-page-header { padding-block: clamp(3rem, 7vw, 5rem) clamp(2rem, 4vw, 3rem); border-bottom: 1px solid var(--aegis-line); position: relative; }
.aegis-page-header .aegis-eyebrow { margin-bottom: 0.8rem; }
.aegis-breadcrumb { font-family: var(--aegis-font-mono); font-size: 0.8rem; color: var(--aegis-text-dim); margin-top: 0.8rem; }
.aegis-breadcrumb a { color: var(--aegis-text-soft); }

/* Sidebar / widgets */
.aegis-sidebar .widget { background: var(--aegis-surface); border: 1px solid var(--aegis-line); border-radius: var(--aegis-radius); padding: 1.5rem; margin-bottom: 1.5rem; }
.aegis-sidebar .widget-title { font-size: 1.05rem; margin-bottom: 1rem; padding-bottom: 0.75rem; border-bottom: 1px solid var(--aegis-line); display: flex; align-items: center; gap: 0.5rem; }
.aegis-sidebar .widget-title::before { content: "▸"; color: var(--aegis-cyan); }
.aegis-sidebar ul { list-style: none; padding: 0; margin: 0; }
.aegis-sidebar ul li { padding: 0.45rem 0; border-bottom: 1px dashed var(--aegis-line); color: var(--aegis-text-soft); }
.aegis-sidebar ul li:last-child { border-bottom: 0; }
.aegis-sidebar a { color: var(--aegis-text-soft); }
.aegis-sidebar a:hover { color: var(--aegis-cyan); }

/* Forms */
input[type="text"], input[type="email"], input[type="url"], input[type="password"],
input[type="search"], input[type="tel"], input[type="number"], textarea, select {
    width: 100%; background: var(--aegis-bg-alt); border: 1px solid var(--aegis-line-strong);
    border-radius: var(--aegis-radius-sm); color: var(--aegis-text); padding: 0.85rem 1rem;
    font-family: var(--aegis-font-body); font-size: 1rem; transition: border-color 0.2s, box-shadow 0.2s;
}
input:focus, textarea:focus, select:focus { border-color: var(--aegis-cyan); box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.15); outline: none; }
label { font-family: var(--aegis-font-display); font-weight: 500; font-size: 0.92rem; display: block; margin-bottom: 0.5rem; }
.aegis-field { margin-bottom: 1.25rem; }

/* Comments */
.aegis-comments { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--aegis-line); }
.comment-list { list-style: none; padding: 0; }
.comment-list .comment { background: var(--aegis-surface); border: 1px solid var(--aegis-line); border-radius: var(--aegis-radius); padding: 1.25rem 1.5rem; margin-bottom: 1.25rem; }
.comment-list .children { list-style: none; padding-left: 1.5rem; margin-top: 1.25rem; }
.comment-author { font-family: var(--aegis-font-display); font-weight: 600; }
.comment-metadata { font-family: var(--aegis-font-mono); font-size: 0.76rem; color: var(--aegis-text-dim); }

/* Pagination */
.aegis-pagination { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-top: 2.5rem; justify-content: center; }
.aegis-pagination .page-numbers {
    display: grid; place-items: center; min-width: 44px; height: 44px; padding: 0 0.75rem;
    border: 1px solid var(--aegis-line); border-radius: var(--aegis-radius-sm);
    color: var(--aegis-text-soft); font-family: var(--aegis-font-mono);
}
.aegis-pagination .page-numbers.current { background: var(--aegis-cyan); color: #04121a; border-color: var(--aegis-cyan); }
.aegis-pagination .page-numbers:hover:not(.current) { border-color: var(--aegis-cyan); color: var(--aegis-cyan); }

/* =========================================================================
   Footer
   ========================================================================= */
.aegis-footer { background: #04070f; border-top: 1px solid var(--aegis-line); padding-block: clamp(3.5rem, 7vw, 5.5rem) 0; }
.aegis-footer-grid { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: 2.5rem; padding-bottom: 3rem; }
.aegis-footer h4 { font-family: var(--aegis-font-mono); font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--aegis-cyan); margin-bottom: 1.25rem; }
.aegis-footer .widget ul { list-style: none; padding: 0; margin: 0; }
.aegis-footer .widget li { padding: 0.4rem 0; }
.aegis-footer a { color: var(--aegis-text-soft); }
.aegis-footer a:hover { color: var(--aegis-cyan); }
.aegis-footer-about p { color: var(--aegis-text-soft); font-size: 0.95rem; }
.aegis-footer-bottom { border-top: 1px solid var(--aegis-line); padding-block: 1.75rem; display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; font-family: var(--aegis-font-mono); font-size: 0.8rem; color: var(--aegis-text-dim); }
.aegis-social { display: flex; gap: 0.6rem; }
.aegis-social a { width: 40px; height: 40px; display: grid; place-items: center; border: 1px solid var(--aegis-line-strong); border-radius: var(--aegis-radius-sm); color: var(--aegis-text-soft); }
.aegis-social a:hover { border-color: var(--aegis-cyan); color: var(--aegis-cyan); transform: translateY(-2px); }

/* =========================================================================
   Accessibility / WP core
   ========================================================================= */
.screen-reader-text {
    border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%);
    height: 1px; width: 1px; margin: -1px; padding: 0; overflow: hidden;
    position: absolute !important; word-wrap: normal !important;
}
.screen-reader-text:focus {
    background: var(--aegis-surface); clip: auto; clip-path: none;
    color: var(--aegis-cyan); display: block; height: auto; width: auto;
    padding: 1rem 1.5rem; left: 1rem; top: 1rem; z-index: 100000; border-radius: var(--aegis-radius-sm);
}
.aegis-skip-link:focus { left: 1rem; top: 1rem; }

.admin-bar .aegis-header { top: 32px; }
@media screen and (max-width: 782px) { .admin-bar .aegis-header { top: 46px; } }

/* Reveal-on-scroll */
.aegis-reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--aegis-ease), transform 0.7s var(--aegis-ease); }
.aegis-reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
    * { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
    .aegis-reveal { opacity: 1; transform: none; }
}

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width: 1024px) {
    .aegis-hero-grid { grid-template-columns: 1fr; }
    .aegis-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .aegis-stats { grid-template-columns: repeat(2, 1fr); }
    .aegis-footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 860px) {
    .aegis-nav-toggle { display: inline-flex; }
    .aegis-nav {
        position: fixed; inset: 0 0 0 auto; width: min(82vw, 360px);
        flex-direction: column; align-items: stretch; gap: 0;
        background: var(--aegis-surface); border-left: 1px solid var(--aegis-line-strong);
        padding: 6rem 1.5rem 2rem; transform: translateX(100%);
        transition: transform 0.3s var(--aegis-ease); z-index: 90; box-shadow: var(--aegis-shadow);
        overflow-y: auto;
    }
    .aegis-nav.is-open { transform: translateX(0); }
    .aegis-menu { flex-direction: column; gap: 0; }
    .aegis-menu a { padding: 0.9rem 0.5rem; border-bottom: 1px solid var(--aegis-line); }
    .aegis-menu ul.sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: 0; background: transparent; padding-left: 1rem; }
    .aegis-header-cta .aegis-btn--ghost { display: none; }
    .aegis-content-wrap, .aegis-feature-split { grid-template-columns: 1fr; }
}

@media (max-width: 620px) {
    .aegis-grid--3, .aegis-grid--4, .aegis-grid--2, .aegis-pricing { grid-template-columns: 1fr; }
    .aegis-stats { grid-template-columns: 1fr 1fr; }
    .aegis-footer-grid { grid-template-columns: 1fr; }
    .aegis-footer-bottom { flex-direction: column; text-align: center; }
}
