/* ==========================================================
   Adamas Tech — Cybersecurity Page Styles
   Scope: all rules prefixed with .cs- to avoid conflicts
   with existing theme / Elementor styles.
   ========================================================== */

/* ---- Root tokens (match site palette) ---- */
.cs-page-wrap {
    --cs-primary:       #1351D8;
    --cs-primary-dark:  #0e3fa8;
    --cs-primary-light: #e8effe;
    --cs-dark:          #0d1b2a;
    --cs-dark-2:        #1a2840;
    --cs-text:          #3a3a3a;
    --cs-text-light:    #666;
    --cs-white:         #ffffff;
    --cs-off-white:     #f7f8fc;
    --cs-border:        #e8eaed;
    --cs-red:           #d0021b;
    --cs-accent:        #7aa8f5;
    --cs-font-main:     'DM Sans', sans-serif;
    --cs-font-head:     'Yantramanav', sans-serif;
    --cs-radius:        8px;
    --cs-shadow:        0 4px 24px rgba(19,81,216,0.10);
    --cs-shadow-lg:     0 8px 40px rgba(19,81,216,0.13);
    font-family: var(--cs-font-main);
    color: var(--cs-text);
    font-size: 16px;
    line-height: 1.7;
}

/* ---- Layout ---- */
.cs-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ---- Shared section spacing ---- */
.cs-page-wrap section { padding: 72px 0; }

/* ---- Shared typography ---- */
.cs-section-eyebrow {
    color: var(--cs-primary);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 12px;
}
.cs-eyebrow-light { color: var(--cs-accent); }

.cs-section-title {
    font-family: var(--cs-font-head);
    font-size: 36px;
    font-weight: 700;
    color: var(--cs-dark);
    line-height: 1.2;
    margin-bottom: 16px;
    letter-spacing: -0.5px;
}
.cs-section-title span { color: var(--cs-primary); }
.cs-title-white { color: var(--cs-white); }

.cs-section-desc {
    font-size: 16px;
    color: var(--cs-text-light);
    line-height: 1.75;
    max-width: 640px;
}
.cs-desc-muted { color: rgba(255,255,255,0.65); }

.cs-section-header-center {
    text-align: center;
    margin-bottom: 48px;
}
.cs-section-header-center .cs-section-desc { margin: 0 auto; }

/* =============================================
   HERO
   ============================================= */
.cs-hero {
    background: linear-gradient(135deg, #0d1b2a 0%, #1a2840 50%, #0e3060 100%);
    color: var(--cs-white);
    padding: 80px 0 60px;
    position: relative;
    overflow: hidden;
}
.cs-hero::before {
    content: '';
    position: absolute; top: -100px; right: -100px;
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(19,81,216,0.25) 0%, transparent 70%);
    border-radius: 50%;
}
.cs-hero::after {
    content: '';
    position: absolute; bottom: -80px; left: -80px;
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(19,81,216,0.15) 0%, transparent 70%);
    border-radius: 50%;
}
.cs-hero-inner {
    position: relative; z-index: 2;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}
.cs-hero-badge {
    display: inline-flex;
    align-items: center; gap: 8px;
    background: rgba(19,81,216,0.25);
    border: 1px solid rgba(19,81,216,0.4);
    color: var(--cs-accent);
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px; font-weight: 600;
    margin-bottom: 20px;
    letter-spacing: 0.5px;
}
.cs-hero-title {
    font-family: var(--cs-font-head);
    font-size: 46px; font-weight: 700;
    line-height: 1.15; margin-bottom: 20px;
    letter-spacing: -1px; color: var(--cs-white);
}
.cs-hero-title span { color: var(--cs-accent); }

.cs-hero-desc {
    font-size: 17px;
    color: rgba(255,255,255,0.75);
    line-height: 1.7; margin-bottom: 32px;
    max-width: 520px;
}
.cs-hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; }

.cs-btn-primary {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--cs-primary); color: var(--cs-white);
    padding: 13px 28px; border-radius: 6px;
    font-size: 15px; font-weight: 600;
    font-family: var(--cs-font-main);
    transition: background .2s, transform .1s;
    text-decoration: none; border: none; cursor: pointer;
}
.cs-btn-primary:hover { background: var(--cs-primary-dark); transform: translateY(-1px); color: var(--cs-white); }

.cs-btn-white {
    display: inline-flex; align-items: center; gap: 6px;
    background: transparent;
    border: 1.5px solid rgba(255,255,255,0.35);
    color: var(--cs-white); padding: 13px 28px;
    border-radius: 6px; font-size: 15px; font-weight: 600;
    font-family: var(--cs-font-main);
    transition: all .2s; text-decoration: none;
}
.cs-btn-white:hover { background: rgba(255,255,255,0.1); color: var(--cs-white); }

.cs-hero-locations {
    margin-top: 28px;
    font-size: 12.5px;
    color: rgba(255,255,255,0.5);
    display: flex; align-items: center; gap: 6px;
}
.cs-hero-locations i { color: var(--cs-accent); }

.cs-hero-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.cs-stat-card {
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 12px; padding: 24px 20px;
    text-align: center;
    backdrop-filter: blur(8px);
}
.cs-stat-number {
    font-family: var(--cs-font-head);
    font-size: 36px; font-weight: 900;
    color: var(--cs-accent); line-height: 1; margin-bottom: 6px;
}
.cs-stat-label { font-size: 13px; color: rgba(255,255,255,0.65); font-weight: 500; }
.cs-stat-sublabel { font-size: 11px; color: rgba(255,255,255,0.45); margin-top: 3px; }

/* =============================================
   THREAT LANDSCAPE
   ============================================= */
.cs-threat-section {
    background: linear-gradient(135deg, #f0f4ff 0%, #e8f0fe 100%);
    border-top: 1px solid #d5e3ff;
    border-bottom: 1px solid #d5e3ff;
}
.cs-threat-grid {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 20px; margin: 40px 0;
}
.cs-threat-card {
    background: var(--cs-white);
    border: 1px solid var(--cs-border);
    border-radius: 12px; padding: 28px 24px;
    text-align: center;
    box-shadow: var(--cs-shadow);
    transition: transform .2s;
}
.cs-threat-card:hover { transform: translateY(-3px); }
.cs-threat-number { font-family: var(--cs-font-head); font-size: 40px; font-weight: 900; color: var(--cs-primary); line-height: 1; margin-bottom: 8px; }
.cs-red { color: var(--cs-red) !important; }
.cs-threat-what { font-size: 14px; font-weight: 700; color: var(--cs-dark); margin-bottom: 6px; }
.cs-threat-sub { font-size: 13px; color: var(--cs-text-light); }

.cs-threat-drivers {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 20px; margin-top: 20px;
}
.cs-driver-item {
    background: var(--cs-white);
    border-left: 4px solid var(--cs-primary);
    border-radius: 0 8px 8px 0;
    padding: 18px 20px;
    box-shadow: var(--cs-shadow);
}
.cs-driver-title { font-size: 15px; font-weight: 700; color: var(--cs-dark); margin-bottom: 5px; }
.cs-driver-desc { font-size: 14px; color: var(--cs-text-light); }

.cs-boardroom-box {
    background: var(--cs-white);
    border-radius: 12px; border: 1px solid var(--cs-border);
    border-left: 4px solid var(--cs-primary);
    padding: 24px 28px; margin-top: 24px;
}
.cs-boardroom-title { font-size: 15px; font-weight: 700; color: var(--cs-dark); margin-bottom: 6px; }
.cs-boardroom-text { font-size: 14.5px; color: var(--cs-text-light); line-height: 1.7; }

/* =============================================
   FOUR PILLARS
   ============================================= */
.cs-pillars-section { background: var(--cs-white); }
.cs-pillars-grid {
    display: grid; grid-template-columns: repeat(4,1fr);
    gap: 24px; margin-top: 48px;
}
.cs-pillar-card {
    border-radius: 14px; overflow: hidden;
    box-shadow: var(--cs-shadow);
    transition: transform .25s, box-shadow .25s;
    border: 1px solid var(--cs-border);
}
.cs-pillar-card:hover { transform: translateY(-5px); box-shadow: var(--cs-shadow-lg); }
.cs-pillar-header {
    padding: 24px 20px; text-align: center; color: var(--cs-white);
}
.cs-pillar-h1 { background: #1351D8; }
.cs-pillar-h2 { background: #0e3fa8; }
.cs-pillar-h3 { background: #0a2d6e; }
.cs-pillar-h4 { background: #07224f; }

.cs-pillar-num { font-family: var(--cs-font-head); font-size: 38px; font-weight: 900; opacity: .25; line-height: 1; }
.cs-pillar-icon {
    width: 52px; height: 52px;
    background: rgba(255,255,255,0.18); border-radius: 50%;
    margin: 8px auto; display: flex; align-items: center; justify-content: center; font-size: 22px;
}
.cs-pillar-name { font-family: var(--cs-font-head); font-size: 18px; font-weight: 700; margin-bottom: 4px; }
.cs-pillar-subtitle { font-size: 13px; opacity: .8; }

.cs-pillar-body { background: var(--cs-white); padding: 20px; }
.cs-pillar-list li {
    font-size: 14px; color: var(--cs-text);
    padding: 6px 0; border-bottom: 1px solid #f0f2f5;
    display: flex; align-items: flex-start; gap: 8px;
    list-style: none;
}
.cs-pillar-list li:last-child { border-bottom: none; }
.cs-pillar-list li::before {
    content: ''; width: 6px; height: 6px;
    background: var(--cs-primary); border-radius: 50%;
    margin-top: 8px; flex-shrink: 0;
}
.cs-pillars-quote {
    text-align: center; margin-top: 28px;
    font-size: 15px; font-style: italic; color: var(--cs-text-light);
}

/* =============================================
   DEFENCE IN DEPTH
   ============================================= */
.cs-defence-section {
    background: linear-gradient(135deg, #0d1b2a 0%, #162035 100%);
    color: var(--cs-white);
}
.cs-defence-layers {
    margin-top: 48px; display: flex; flex-direction: column;
    border-radius: 14px; overflow: hidden;
    border: 1px solid rgba(255,255,255,0.1);
}
.cs-defence-layer {
    display: grid; grid-template-columns: 200px 1fr;
    align-items: stretch;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    transition: background .2s;
}
.cs-defence-layer:last-child { border-bottom: none; }
.cs-defence-layer:hover { background: rgba(19,81,216,0.12); }

.cs-layer-label {
    background: rgba(19,81,216,0.2);
    padding: 20px 24px; display: flex; align-items: center; gap: 12px;
    border-right: 1px solid rgba(255,255,255,0.08);
}
.cs-layer-icon {
    width: 36px; height: 36px; background: var(--cs-primary);
    border-radius: 8px; display: flex; align-items: center;
    justify-content: center; font-size: 15px; flex-shrink: 0;
}
.cs-layer-name { font-size: 14px; font-weight: 700; color: var(--cs-white); letter-spacing: 0.5px; text-transform: uppercase; }
.cs-layer-controls {
    padding: 20px 28px; font-size: 14px; color: rgba(255,255,255,0.7);
    display: flex; align-items: center; flex-wrap: wrap; gap: 12px;
}
.cs-layer-tag {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    padding: 4px 12px; border-radius: 20px;
    font-size: 12.5px; color: rgba(255,255,255,0.8); white-space: nowrap;
}
.cs-defence-extras {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 20px; margin-top: 24px;
}
.cs-defence-extra {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 12px; padding: 24px;
}
.cs-extra-title { font-size: 15px; font-weight: 700; color: var(--cs-accent); margin-bottom: 8px; }
.cs-extra-desc { font-size: 14px; color: rgba(255,255,255,0.6); }

/* =============================================
   MATURITY ROADMAP
   ============================================= */
.cs-maturity-section { background: var(--cs-off-white); }
.cs-maturity-track {
    display: grid; grid-template-columns: repeat(5,1fr);
    gap: 0; margin-top: 48px; position: relative;
}
.cs-maturity-track::before {
    content: ''; position: absolute;
    top: 44px; left: 10%; right: 10%; height: 3px;
    background: linear-gradient(90deg, #e8eaed, var(--cs-primary), #0e3fa8);
    z-index: 0;
}
.cs-tier-card { text-align: center; padding: 0 10px; position: relative; z-index: 1; }
.cs-tier-dot {
    width: 44px; height: 44px; border-radius: 50%;
    margin: 0 auto 16px; display: flex; align-items: center;
    justify-content: center; font-size: 13px; font-weight: 800;
    border: 3px solid var(--cs-white);
}
.cs-t0 { background: #e8eaed; color: #888; box-shadow: 0 0 0 3px var(--cs-border); }
.cs-t1 { background: #ffd6d9; color: var(--cs-red); box-shadow: 0 0 0 3px rgba(208,2,27,0.2); }
.cs-t2 { background: #fff0cc; color: #b8860b; box-shadow: 0 0 0 3px rgba(184,134,11,0.2); }
.cs-t3 { background: #d0e8ff; color: var(--cs-primary); box-shadow: 0 0 0 3px rgba(19,81,216,0.2); }
.cs-t4 { background: var(--cs-primary); color: var(--cs-white); box-shadow: 0 0 0 3px rgba(19,81,216,0.3); }

.cs-tier-num { font-size: 11px; font-weight: 700; color: var(--cs-primary); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 4px; }
.cs-tier-name { font-family: var(--cs-font-head); font-size: 15px; font-weight: 700; color: var(--cs-dark); margin-bottom: 4px; }
.cs-tier-month { font-size: 12px; color: var(--cs-primary); font-weight: 600; margin-bottom: 10px; }
.cs-tier-points {
    text-align: left; padding: 12px;
    background: var(--cs-white); border-radius: 8px; border: 1px solid var(--cs-border);
}
.cs-tier-points li { font-size: 12.5px; color: var(--cs-text-light); padding: 3px 0; border-bottom: 1px solid #f5f5f5; list-style: none; }
.cs-tier-points li:last-child { border-bottom: none; }
.cs-maturity-legend { text-align: center; margin-top: 28px; font-size: 14px; color: var(--cs-text-light); font-weight: 500; letter-spacing: 0.5px; }
.cs-maturity-legend strong { color: var(--cs-primary); }

/* =============================================
   MANAGED SOC
   ============================================= */
.cs-soc-section { background: var(--cs-white); }
.cs-soc-intro { font-size: 16px; color: var(--cs-text-light); margin-bottom: 28px; }
.cs-soc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 48px; align-items: start; }
.cs-soc-steps { display: flex; flex-direction: column; gap: 0; }
.cs-soc-step { display: flex; gap: 20px; padding: 24px 0; border-bottom: 1px solid var(--cs-border); }
.cs-soc-step:last-child { border-bottom: none; }
.cs-step-num {
    width: 40px; height: 40px; background: var(--cs-primary); color: var(--cs-white);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 15px; flex-shrink: 0;
}
.cs-step-title { font-size: 16px; font-weight: 700; color: var(--cs-dark); margin-bottom: 5px; }
.cs-step-desc { font-size: 14px; color: var(--cs-text-light); }

.cs-soc-right { display: flex; flex-direction: column; gap: 20px; }
.cs-soc-sla-card {
    background: linear-gradient(135deg, #f0f4ff, #e8f0fe);
    border: 1px solid #d5e3ff; border-radius: 14px; padding: 28px;
}
.cs-sla-title { font-size: 14px; font-weight: 700; color: var(--cs-primary); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 18px; }
.cs-sla-items { display: flex; flex-direction: column; gap: 14px; }
.cs-sla-item { display: flex; align-items: center; gap: 16px; }
.cs-sla-value { font-family: var(--cs-font-head); font-size: 28px; font-weight: 900; color: var(--cs-primary); min-width: 90px; }
.cs-sla-desc { font-size: 14px; color: var(--cs-text); font-weight: 500; }

.cs-monitor-card { background: var(--cs-dark); border-radius: 14px; padding: 28px; color: var(--cs-white); }
.cs-monitor-title { font-size: 14px; font-weight: 700; color: var(--cs-accent); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; }
.cs-monitor-title-mt { margin-top: 20px; }
.cs-monitor-list li {
    font-size: 14px; color: rgba(255,255,255,0.75);
    padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,0.08);
    display: flex; gap: 10px; align-items: flex-start; list-style: none;
}
.cs-monitor-list li:last-child { border-bottom: none; }
.cs-monitor-list li::before { content: '▸'; color: var(--cs-accent); flex-shrink: 0; }
.cs-engage-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }
.cs-engage-tag {
    background: rgba(19,81,216,0.15);
    border: 1px solid rgba(19,81,216,0.3);
    color: var(--cs-accent); padding: 6px 14px;
    border-radius: 20px; font-size: 13px; font-weight: 600;
}

/* =============================================
   OFFENSIVE SECURITY
   ============================================= */
.cs-offensive-section { background: var(--cs-off-white); }
.cs-offensive-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 48px; }
.cs-offensive-card {
    background: var(--cs-white); border: 1px solid var(--cs-border);
    border-radius: 12px; padding: 28px 24px;
    box-shadow: var(--cs-shadow); transition: transform .2s;
}
.cs-offensive-card:hover { transform: translateY(-4px); }
.cs-off-icon {
    width: 48px; height: 48px; background: var(--cs-primary-light);
    border-radius: 10px; display: flex; align-items: center;
    justify-content: center; font-size: 20px; color: var(--cs-primary); margin-bottom: 16px;
}
.cs-off-title { font-size: 16px; font-weight: 700; color: var(--cs-dark); margin-bottom: 4px; }
.cs-off-subtitle { font-size: 12.5px; color: var(--cs-primary); font-weight: 600; margin-bottom: 14px; }
.cs-off-list li {
    font-size: 13.5px; color: var(--cs-text-light);
    padding: 5px 0; border-bottom: 1px solid #f5f5f5;
    display: flex; gap: 8px; align-items: flex-start; list-style: none;
}
.cs-off-list li:last-child { border-bottom: none; }
.cs-off-list li::before { content: ''; width: 5px; height: 5px; background: var(--cs-primary); border-radius: 50%; margin-top: 9px; flex-shrink: 0; }

.cs-cadence-bar {
    background: var(--cs-white); border: 1px solid var(--cs-border);
    border-radius: 10px; padding: 20px 28px; margin-top: 24px;
    display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.cs-cadence-label { font-size: 13px; font-weight: 700; color: var(--cs-primary); text-transform: uppercase; letter-spacing: 1px; margin-right: 8px; flex-shrink: 0; }
.cs-cadence-item { font-size: 13.5px; color: var(--cs-text); padding: 5px 14px; background: var(--cs-off-white); border: 1px solid var(--cs-border); border-radius: 20px; }

/* =============================================
   COMPLIANCE
   ============================================= */
.cs-compliance-section { background: var(--cs-white); padding: 56px 0; }
.cs-compliance-grid { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 32px; }
.cs-compliance-badge {
    background: var(--cs-off-white); border: 1.5px solid var(--cs-border);
    border-radius: 8px; padding: 12px 20px;
    font-size: 13px; font-weight: 700; color: var(--cs-dark);
    letter-spacing: 0.5px; transition: all .2s;
}
.cs-compliance-badge:hover { border-color: var(--cs-primary); color: var(--cs-primary); background: var(--cs-primary-light); }

/* =============================================
   CASE STUDIES
   ============================================= */
.cs-cases-section { background: var(--cs-off-white); }
.cs-cases-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; margin-top: 48px; }
.cs-case-card {
    border: 1px solid var(--cs-border); border-radius: 14px;
    overflow: hidden; box-shadow: var(--cs-shadow);
    transition: transform .25s, box-shadow .25s;
}
.cs-case-card:hover { transform: translateY(-4px); box-shadow: var(--cs-shadow-lg); }
.cs-case-header { padding: 22px 24px; color: var(--cs-white); }
.cs-case-h1 { background: #1351D8; }
.cs-case-h2 { background: #0e3fa8; }
.cs-case-h3 { background: #0a2d6e; }
.cs-case-h4 { background: #07224f; }
.cs-case-tag { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; opacity: .7; margin-bottom: 6px; }
.cs-case-title { font-size: 17px; font-weight: 700; line-height: 1.35; }
.cs-case-body { padding: 24px; }
.cs-case-meta { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--cs-border); }
.cs-meta-label { font-size: 11px; color: var(--cs-text-light); font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 3px; }
.cs-meta-value { font-size: 14px; font-weight: 700; color: var(--cs-dark); }
.cs-case-blocks { display: flex; flex-direction: column; gap: 14px; }
.cs-case-block-title { font-size: 12px; font-weight: 700; color: var(--cs-primary); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 5px; }
.cs-case-block-text { font-size: 14px; color: var(--cs-text-light); line-height: 1.6; }
.cs-case-impact {
    background: linear-gradient(135deg, #f0f4ff, #e8f0fe);
    border: 1px solid #d5e3ff; border-radius: 10px; padding: 16px 18px; margin-top: 16px;
}
.cs-impact-title { font-size: 12px; font-weight: 700; color: var(--cs-primary); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.cs-impact-item {
    font-size: 13.5px; color: var(--cs-dark); font-weight: 500;
    padding: 4px 0; display: flex; gap: 8px; align-items: flex-start;
}
.cs-impact-item::before { content: '✓'; color: var(--cs-primary); font-weight: 700; flex-shrink: 0; }
.cs-case-tools { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.cs-tool-tag {
    background: var(--cs-off-white); border: 1px solid var(--cs-border);
    padding: 4px 12px; border-radius: 4px;
    font-size: 11px; font-weight: 700; color: var(--cs-text-light); letter-spacing: 0.5px;
}

/* =============================================
   WHY ADAMAS
   ============================================= */
.cs-why-section {
    background: linear-gradient(135deg, #f0f4ff, #e8f0fe);
    border-top: 1px solid #d5e3ff;
}
.cs-why-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; margin-top: 48px; }
.cs-why-card {
    background: var(--cs-white); border: 1px solid var(--cs-border);
    border-radius: 14px; padding: 32px 28px;
    display: flex; gap: 20px; box-shadow: var(--cs-shadow); transition: transform .2s;
}
.cs-why-card:hover { transform: translateY(-3px); }
.cs-why-num { font-family: var(--cs-font-head); font-size: 42px; font-weight: 900; color: #d5e3ff; line-height: 1; flex-shrink: 0; min-width: 48px; }
.cs-why-title { font-size: 18px; font-weight: 700; color: var(--cs-dark); margin-bottom: 8px; }
.cs-why-desc { font-size: 15px; color: var(--cs-text-light); line-height: 1.65; }
.cs-why-quote-box {
    background: var(--cs-primary); border-radius: 14px;
    padding: 40px; text-align: center; margin-top: 40px; color: var(--cs-white);
}
.cs-quote-text { font-family: var(--cs-font-head); font-size: 22px; font-weight: 700; font-style: italic; line-height: 1.5; margin-bottom: 12px; }
.cs-quote-attr { font-size: 14px; opacity: .75; }

/* =============================================
   CTA / CONTACT
   ============================================= */
.cs-cta-section { background: var(--cs-dark); color: var(--cs-white); padding: 80px 0; }
.cs-cta-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.cs-contact-details { margin-top: 28px; }
.cs-contact-label { font-size: 14px; color: rgba(255,255,255,0.55); margin-bottom: 8px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }
.cs-contact-item { font-size: 15px; color: rgba(255,255,255,0.8); margin-bottom: 4px; display: flex; align-items: center; gap: 8px; }
.cs-contact-item i { color: var(--cs-accent); }
.cs-cta-offices { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 28px; }
.cs-office-item { display: flex; gap: 12px; align-items: flex-start; }
.cs-office-flag { font-size: 22px; }
.cs-office-city { font-size: 14px; font-weight: 700; color: var(--cs-white); }
.cs-office-role { font-size: 12.5px; color: rgba(255,255,255,0.55); }

.cs-contact-form-box {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 16px; padding: 36px 32px;
}
.cs-form-title { font-family: var(--cs-font-head); font-size: 22px; font-weight: 700; color: var(--cs-white); margin-bottom: 6px; }
.cs-form-subtitle { font-size: 14px; color: rgba(255,255,255,0.55); margin-bottom: 24px; }
.cs-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cs-form-group { margin-bottom: 16px; }
.cs-form-group label { display: block; font-size: 13px; font-weight: 600; color: rgba(255,255,255,0.75); margin-bottom: 6px; }
.cs-form-group input,
.cs-form-group select,
.cs-form-group textarea {
    width: 100%; background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 7px; padding: 11px 14px;
    font-size: 14px; color: var(--cs-white);
    font-family: var(--cs-font-main); outline: none; transition: border-color .2s;
}
.cs-form-group input::placeholder,
.cs-form-group textarea::placeholder { color: rgba(255,255,255,0.35); }
.cs-form-group input:focus,
.cs-form-group textarea:focus { border-color: var(--cs-accent); }
.cs-form-group select { color: rgba(255,255,255,0.7); }
.cs-form-group select option { background: #1a2840; color: var(--cs-white); }
.cs-form-submit {
    width: 100%; background: var(--cs-primary); color: var(--cs-white);
    border: none; border-radius: 7px; padding: 13px;
    font-size: 15px; font-weight: 700; cursor: pointer;
    font-family: var(--cs-font-main);
    display: flex; align-items: center; justify-content: center; gap: 8px;
    transition: background .2s; margin-top: 6px;
}
.cs-form-submit:hover { background: var(--cs-primary-dark); }
.cs-form-privacy { font-size: 12px; color: rgba(255,255,255,0.35); text-align: center; margin-top: 12px; }

/* Native form: match CF7 reset */
.cs-native-form .wpcf7-not-valid-tip { color: #ff6b6b; font-size: 12px; margin-top: 4px; }
.cs-native-form .wpcf7-response-output { margin-top: 12px; padding: 10px 14px; border-radius: 6px; font-size: 14px; }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 1024px) {
    .cs-hero-inner  { grid-template-columns: 1fr; gap: 40px; }
    .cs-hero-stats  { grid-template-columns: repeat(4,1fr); }
    .cs-pillars-grid { grid-template-columns: repeat(2,1fr); }
    .cs-threat-grid  { grid-template-columns: repeat(2,1fr); }
    .cs-maturity-track { grid-template-columns: 1fr; gap: 16px; }
    .cs-maturity-track::before { display: none; }
    .cs-offensive-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 768px) {
    .cs-hero-title   { font-size: 32px; }
    .cs-section-title { font-size: 26px; }
    .cs-hero-stats   { grid-template-columns: repeat(2,1fr); }
    .cs-soc-grid     { grid-template-columns: 1fr; }
    .cs-cases-grid   { grid-template-columns: 1fr; }
    .cs-cta-inner    { grid-template-columns: 1fr; }
    .cs-why-grid     { grid-template-columns: 1fr; }
    .cs-defence-layer { grid-template-columns: 1fr; }
    .cs-layer-label  { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.08); }
    .cs-offensive-grid { grid-template-columns: 1fr; }
    .cs-threat-drivers { grid-template-columns: 1fr; }
    .cs-defence-extras { grid-template-columns: 1fr; }
    .cs-form-row     { grid-template-columns: 1fr; }
    .cs-case-meta    { grid-template-columns: 1fr 1fr; }
    .cs-cta-offices  { grid-template-columns: 1fr; }
    .cs-pillars-grid { grid-template-columns: 1fr; }
    .cs-threat-grid  { grid-template-columns: 1fr; }
}
