.right-stick{position:sticky; top:100px}
.right-panel-sticky{position:sticky; top:100px; max-height:calc(100vh - 120px); overflow:auto}
/* Extracted minimal landing styles for public home view */
:root { --primary-color:#0056b3; --secondary-color:#007bff; --dark-blue:#003366; --success-color:#198754; --light-bg:#f8f9fa; --light-gray:#e9ecef; --text-color:#212529; --text-muted:#6c757d; --white-color:#ffffff; --border-color:#dee2e6; }
.landing .container, .public-header .container { width:90%; max-width:1140px; margin:0 auto; padding:0 15px; }
.landing section { padding:80px 0; scroll-margin-top: 80px; }
.landing h1,.landing h2,.landing h3 { color:var(--dark-blue); font-weight:700; line-height:1.2; }
.landing h1{font-size:2.8rem; font-family:'Montserrat', Arial, sans-serif; font-weight:800} .landing h2{font-size:2.2rem; margin-bottom:40px; font-family:'Montserrat', Arial, sans-serif; font-weight:700} .landing h3{font-size:1.4rem}
.landing a{color:var(--primary-color); text-decoration:none; transition:color .2s}
.landing a:hover{color:var(--secondary-color); text-decoration:none}

/* Override global a:hover underline for cinematic landing */
.landing-cinematic a,
.landing-cinematic a:hover,
.landing-cinematic a:focus,
.landing-cinematic a:active {
    text-decoration: none !important;
}
.landing .btn{display:inline-block; padding:12px 24px; font-size:1rem; font-weight:600; text-align:center; border-radius:6px; border:2px solid transparent; cursor:pointer; transition:all .3s ease}
.landing .btn-primary{background:var(--primary-color); color:#fff; border-color:var(--primary-color)}
.landing .btn-primary:hover{background:var(--secondary-color); border-color:var(--secondary-color)}
/* Ensure button label stays visible on hover (override global anchor hover) */
.landing .btn:hover{color:#fff}
.landing .btn-secondary{background:transparent; color:var(--dark-blue); border-color:var(--dark-blue)}
.landing .btn-secondary:hover{background:var(--dark-blue); color:#fff}
.landing .hero{background-image:url(../images/dots.png); background-color:#0b1b3a; min-height:calc(100vh - 90px); padding:64px 0; text-align:center; color:#e5e7eb; position:relative; display:flex; align-items:center}
.landing .hero h1{max-width:900px; margin:0 auto 16px; color:#ffffff}
.landing .hero h2{font-size:1.2rem; font-weight:400; color:#c7d2fe; max-width:760px; margin:0 auto 28px; line-height:1.8}
.landing .hero .scroll-down{position:absolute; bottom:24px; left:50%; transform:translateX(-50%); color:#c7d2fe; opacity:.8; display:flex; align-items:center; gap:8px; font-weight:600}
.landing .hero .scroll-down .bi{animation:bounce 1.6s infinite}
/* Na publicznym landingu nie pokazujemy ikony przewijania pod hero */
.landing .scroll-down{display:none!important}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.landing .trust-bar{margin-top:30px; display:flex; justify-content:center; align-items:center; gap:20px; flex-wrap:wrap; color:var(--text-muted); font-weight:600}
.landing .trust-bar .bi{margin-right:6px; color:var(--primary-color)}
/* Hero-specific overrides: white icons and light text */
.landing .hero .trust-bar{color:#c7d2fe}
.landing .hero .trust-bar .bi{color:#ffffff}
.landing .grid-3{display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:24px; text-align:center}
.landing .feature-card{background:#fff; padding:24px; border-radius:8px; border:1px solid var(--border-color); transition:transform .2s ease, box-shadow .2s ease}
.landing .feature-card:hover{transform:translateY(-4px); box-shadow:0 10px 20px rgba(0,0,0,.07)}
.landing .solution{
    /* Ciemny gradient – dokładnie ten sam co w HERO */
    background: radial-gradient(circle at top right, #1e293b 0%, #0f172a 60%) !important;
    color:#e5e7eb;
    position:relative;
    overflow-x:hidden;  /* nie wyjeżdżaj poza viewport w poziomie (radar / glow) */
    overflow-y:hidden;
}

/* Glow effect dla sekcji Solution - kopia z Hero */
.landing .solution::before {
    content: '';
    position: absolute;
    width: 600px;
    height: 600px;
    background: #3b82f6;
    filter: blur(150px);
    opacity: 0.12;
    top: -300px;
    right: -150px;
    border-radius: 50%;
    z-index: 0;
    pointer-events: none;
}
.landing .pricing-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:32px; align-items:stretch}
.landing .pricing-card{background:#fff; border:1px solid var(--border-color); border-radius:12px; padding:28px; text-align:center; transition:transform .2s ease, box-shadow .2s ease; position:relative; display:flex; flex-direction:column}
.landing .pricing-card:hover{transform:translateY(-6px); box-shadow:0 12px 28px rgba(0,0,0,.08)}
.landing .pricing-card.popular{border:2px solid var(--primary-color); padding-top:36px; padding-bottom:36px; min-height:580px; background:#f7fbff}
.landing .pricing-card.popular{box-shadow:0 16px 36px rgba(0,86,179,.15); transform:translateY(-4px)}
.landing .price{font-size:2rem; font-weight:700; margin:10px 0}
.landing .pricing-card p{margin-bottom:12px}
.landing .pricing-card .action-link{margin-top:auto}
.landing .final-cta{
    /* Ciemny gradient jak w hero / solution + dużo oddechu nad i pod CTA */
    background: radial-gradient(circle at top right, #1e293b 0%, #0f172a 60%) !important;
    color:#f9fafb;
    text-align:center;
    padding:8rem 0 7rem; /* jeszcze większa wysokość, żeby glow był w całości w sekcji CTA */
    position:relative;
    z-index:0; /* osobny stacking context – glow może być „pod” sekcją */
}
.landing .final-cta::before{
    /* Ten sam niebieski glow co w hero – spójne tło na dole strony */
    content:'';
    position:absolute;
    width:480px;
    height:480px;
    background:#3b82f6;
    filter:blur(150px);
    opacity:0.17;
    top:-80px; /* jeszcze niżej – glow prawie w środku CTA, daleko od białej sekcji nad nią */
    right:0;  /* trzymaj glow w obrębie szerokości sekcji, bez wychodzenia poza viewport */
    border-radius:50%;
    z-index:-1; /* glow pod tłem CTA, więc biała sekcja powyżej zawsze go przykryje na krawędzi */
}
.landing .final-cta h2{
    background: linear-gradient(to right, #ffffff, #94a3b8);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    color:transparent;
}
.landing footer{background:var(--light-bg); padding:30px 0; border-top:1px solid var(--border-color)}
/* Public footer (landing) */
.public-footer{background:#0b1b3a; color:#c7d2fe; padding:30px 0;}
.public-footer a{color:#c7d2fe; text-decoration:none; margin-right:18px; font-weight:400; transition:color .2s ease, opacity .2s ease}
/* Enforce normal weight for footer links (only headings are bold) */
.public-footer .footer-col li a,.public-footer .footer-bottom a{font-weight:400 !important}
.public-footer a:hover{color:#ffffff; text-decoration:none; opacity:0.95}
.public-footer .footer-bottom{margin-top:10px; color:#ffffff}
.public-footer .footer-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:24px;}
.public-footer .footer-col h5{color:#ffffff; font-weight:700; margin-bottom:10px; font-size:0.95rem}
.public-footer .footer-col ul{list-style:none; margin:0; padding:0}
.public-footer .footer-col li{margin-bottom:8px}
.public-footer .footer-contact{color:#c7d2fe; text-decoration:none}
.public-footer .footer-contact:hover{color:#ffffff}
.public-footer .footer-social-link{color:#c7d2fe; font-size:1.2rem}
.public-footer .footer-social-link:hover{color:#ffffff}
@media (max-width:768px){ .landing h1{font-size:2rem} .landing h2{font-size:1.6rem} }

/* Top navbar for landing */
.landing .landing-navbar,.public-header{background:#fff; border-bottom:1px solid var(--border-color); position:sticky; top:36px; z-index:10}
.landing .nav-container,.public-header .nav-container{display:flex; justify-content:space-between; align-items:center; padding:12px 0; gap:16px}
.landing .brand,.public-header .brand{font-weight:700; color:var(--dark-blue)}
.landing .nav-menu,.public-header .nav-menu{list-style:none; display:flex; gap:24px; margin:0; padding:0}
.landing .nav-menu a,.public-header .nav-menu a{font-weight:600; color:var(--text-color)}
.landing .nav-actions,.public-header .nav-actions{display:flex; gap:12px; align-items:center}
.landing .lang-switch,.public-header .lang-switch,.lang-bar .lang-switch{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
}
.landing .lang-item,.public-header .lang-item,.lang-bar .lang-item{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:26px;
    height:26px;
    padding:0;
    border:1px solid var(--border-color);
    border-radius:50%; /* pełne koło */
    font-weight:500;
    font-size:.7rem; /* dwuliterowy kod się mieści */
    color:#ffffff;
    background:transparent;
    overflow:hidden;
}
.landing .lang-item.active,.public-header .lang-item.active,.lang-bar .lang-item.active{
    border-color:var(--primary-color);
    background:#e0edff;
    color:var(--primary-color);
}

/* Top language bar */
.landing .lang-bar,.lang-bar{
    position:sticky;
    top:0;
    z-index:11;
    background:#f7f9fc;
    border-bottom:1px solid var(--border-color);
    display:flex;
    justify-content:center;
    align-items:center;
}
.landing .lang-bar .lang-container,.lang-bar .lang-container{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:6px 0;
    margin:0;
    width:90%;
    max-width:1140px;
}
.lang-bar .lang-group{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:15px;
    width:100%;
}
.landing .lang-bar .lang-label,.lang-bar .lang-label{
    display:flex;
    align-items:center;
    gap:6px;
    font-size:0.72rem; /* ok. 11-12px */
    font-weight:600;
    color:var(--primary-color);
    letter-spacing:0.5px;
    text-transform:none;
    white-space:nowrap; /* nie łam tekstu "Dostępny w 22 językach" */
}
.lang-bar .lang-label .lang-count{
    font-weight:600;
    color:var(--text-muted);
    text-transform:none;
}

/* Dropdown z dodatkowymi językami */
.lang-bar .lang-more{
    position:relative;
}
.lang-bar .lang-more-btn{
    padding:2px 10px;
    border-radius:999px;
    border:1px solid var(--border-color);
    background:#ffffff;
    font-size:.78rem;
    font-weight:500;
    color:var(--text-color);
    cursor:pointer;
}
.lang-bar .lang-more-menu{
    /* Domyślnie ukryte; display ustawiamy w stanie aktywnym */
    display:none;
    position:absolute;
    right:0;
    top:100%; /* tuż pod przyciskiem, bez przerwy żeby kursor nie gubił hovera */
    background:#ffffff;
    border:1px solid var(--border-color);
    border-radius:8px;
    padding:10px 12px;
    box-shadow:0 4px 12px rgba(0,0,0,0.15);
    min-width:auto;
    z-index:50;
}
.lang-bar .lang-more-menu .lang-item{
    display:block;
    margin-bottom:4px;
}
.lang-bar .lang-more-menu .lang-item:last-child{
    margin-bottom:0;
}
.lang-bar .lang-more:hover .lang-more-menu,
.lang-bar .lang-more:focus-within .lang-more-menu{
    /* Aktywny stan – pokazujemy grid 4xN */
    display:grid;
    grid-template-columns: repeat(4, 30px);
    grid-auto-rows: 30px;
    gap:12px;
}
.lang-bar .lang-more:hover .lang-more-menu .lang-item,
.lang-bar .lang-more:focus-within .lang-more-menu .lang-item{
    font-size:0;            /* ukryj tekst – zostaje sama flaga */
    padding:0;
    margin:0;
}

/* Mobile layout for public header / landing nav – burger menu */
.public-nav-toggle{
  display:none;
  border:none;
  background:transparent;
  padding:4px 8px;
  font-size:1.5rem;
  cursor:pointer;
}
.public-nav-toggle .bi{
  line-height:1;
}

@media (max-width: 900px){
  .public-header .nav-container{
    padding:10px 0;
    flex-wrap:wrap;               /* pozwól, żeby nav i actions zwinęły się pod pierwszy wiersz (logo + burger) */
    align-items:center;
  }
  .public-nav-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-left:auto;
  }
  .public-header nav,
  .public-header .nav-actions{
    display:none;
    flex-direction:column;
    align-items:flex-start;
    width:100%;
    margin-top:8px;
    background:#ffffff;
    border-top:1px solid var(--border-color);
    padding:8px 0 10px;
  }
  .public-header .nav-menu{
    flex-direction:column;
    gap:4px;
    margin-top:4px;
  }
  .public-header .nav-menu li a{
    display:block;
    padding:4px 0;
  }
  .public-header .nav-actions{
    gap:6px;
    margin-top:6px;
  }
  .public-header .nav-actions .action-link{
    padding:4px 0;
    width:100%;           /* linki akcji w osobnych wierszach pod menu */
  }
  /* Na mobile sekcja „Funkcje" działa jak zwykły link – bez rozwijanego megamenu */
  .public-header .megamenu{display:none !important;}
  .public-header .megamenu-trigger .bi-chevron-down{display:none;}
  
  /* Mobilna lista produktów pod „Funkcje" (tylko w burgerze) */
  .public-header .nav-submenu-mobile{
    display:none;
    list-style:none;
    padding:0 0 0 16px;
    margin:4px 0 0 0;
    flex-direction:column;
    gap:2px;
  }
  .public-header.nav-open .nav-submenu-mobile{
    display:flex;
  }
  .public-header .nav-submenu-mobile li a{
    display:block;
    padding:3px 0;
    font-size:0.88rem;
    color:var(--text-muted);
    font-weight:400;
  }
  
  .public-header.nav-open nav,
  .public-header.nav-open .nav-actions{
    display:flex;
  }
}

/* Action links consistent with app style */
.landing .action-link,.public-header .action-link{display:inline-flex; align-items:center; gap:6px; color:#6b5bd2; text-decoration:none; font-weight:600}
.landing .action-link:hover,.public-header .action-link:hover{text-decoration:underline}
.landing .action-link.primary,.public-header .action-link.primary{color:#0056b3}

/* Mega menu */
.public-header .nav-menu{position:relative}
.public-header .nav-menu .has-megamenu{position:relative}
.public-header .megamenu{display:none; position:absolute; top:100%; left:50%; transform:translateX(-50%); background:#fff; border:1px solid var(--border-color); border-radius:8px; box-shadow:0 8px 24px rgba(0,0,0,0.12); padding:24px; min-width:600px; z-index:1000}
.public-header .has-megamenu:hover .megamenu{display:block}
/* Keep open when focusing inside with keyboard/touch */
.public-header .has-megamenu:focus-within .megamenu{display:block}
/* Ukryj mobilną listę produktów na desktopie (pokazuje się tylko w burgerze na mobile) */
.public-header .nav-submenu-mobile{display:none;}
.public-header .megamenu-inner{width:100%}
.public-header .megamenu-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:16px}
.public-header .megamenu-item{display:flex; align-items:flex-start; gap:12px; padding:16px; border-radius:6px; text-decoration:none; transition:background 0.2s}
.public-header .megamenu-item:hover{background:var(--light-bg)}
.public-header .megamenu-icon{font-size:1.5rem; color:var(--primary-color); flex-shrink:0}
.public-header .megamenu-content{flex:1; text-align:left}
.public-header .megamenu-title{font-weight:700; color:var(--dark-blue); margin-bottom:4px; font-size:0.95rem}
.public-header .megamenu-desc{font-size:0.8rem; color:var(--text-muted); line-height:1.4}
.public-header .megamenu-trigger .bi-chevron-down{font-size:0.7rem; transition:transform 0.2s}
.public-header .has-megamenu:hover .megamenu-trigger .bi-chevron-down{transform:rotate(180deg)}

/* Gdy header ma klasę nav-open (burger kliknięty), zawsze pokaż nav + akcje – także przy ręcznym resize okna */
.public-header.nav-open nav,
.public-header.nav-open .nav-actions{
  display:flex !important;
}

/* Steps + FAQ + audience */
.landing .steps-container{display:flex; gap:24px; justify-content:space-between; flex-wrap:wrap}
.landing .step{flex:1 1 260px; text-align:center}
.landing .step-number{width:48px; height:48px; border-radius:50%; background:var(--light-gray); border:2px solid var(--border-color); color:var(--primary-color); display:flex; align-items:center; justify-content:center; margin:0 auto 12px; font-weight:700}

/* Problem section – białe tło */
.landing #problem{
    background:#ffffff !important;
}

/* Gradientowe nagłówki h2 na jasnym tle (sekcje landingowe) */
.landing #latest-posts h2.heading-muted,
.landing #problem h2.heading-muted,
.landing #how-it-works h2.heading-muted,
.landing #features h2.heading-muted,
.landing #pricing h2.heading-muted,
.landing #audience h2.heading-muted,
.landing #faq h2.heading-muted {
    background: linear-gradient(to right, #0f172a, #1d4ed8);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    color:transparent;
}

/* Nagłówek sekcji Solution – taki sam gradient jak hero, bo stoi na ciemnym tle */
.landing .solution h2.heading-muted{
    background: linear-gradient(to right, #ffffff, #94a3b8);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    color:transparent;
}

/* (Sekcja `#features` wróciła do jasnego stylu, więc dodatkowe dark-cards usunięte) */
.landing .faq-item{border-bottom:1px solid var(--border-color); padding:16px 0}
.landing .faq-question{font-weight:600}
.landing .faq-answer{color:var(--text-muted)}

/* Module visualizer (hub and spokes) – Dark Premium */
.landing .module-visualizer{
    position:relative;
    width:480px;
    height:480px;
    margin:24px auto;
}

/* SVG "radar" layer pod hubem */
.landing .module-connections{
    position:absolute;
    inset:0;
    margin:auto;
    width:480px;
    height:480px;
    z-index:0;
    pointer-events:none;
    filter: drop-shadow(0 0 18px rgba(56,189,248,0.45));
    transform-origin:50% 50%;
    animation: radarSpin 60s linear infinite;
}
.landing .module-connections .radar-ring,
.landing .module-connections .radar-line{
    fill:none;
    stroke-width:1;
    stroke-dasharray:5 6;
    stroke-linecap:round;
}

.landing .core-hub,
.landing .module-spoke{
    position:relative;
    z-index:1;
}
.landing .core-hub{
    width:160px;
    height:160px;
    border-radius:50%;
    background: radial-gradient(circle at top, #1d4ed8, #020617);
    color:#eef2ff;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
    box-shadow:
        0 0 0 4px rgba(15,23,42,0.95),
        0 0 0 10px rgba(37,99,235,0.55),
        0 30px 80px rgba(0,0,0,0.85);
    border:1px solid rgba(148,163,184,0.4);
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
}
.landing .core-hub strong{
    font-weight:700;
    letter-spacing:0.03em;
}
.landing .core-hub span{
    font-size:0.8rem;
    opacity:0.85;
}
.landing .module-spoke{
    --angle:0deg;
    --distance:200px;
    position:absolute;
    left:50%;
    top:50%;
    transform:rotate(var(--angle)) translate(var(--distance)) rotate(calc(-1 * var(--angle)));
}
.landing .module-node{
    width:110px;
    text-align:center;
    display:flex;
    flex-direction:column;
    align-items:center;
    transform:translate(-50%, -50%);
}
.landing .module-icon{
    width:60px;
    height:60px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(59,130,246,0.5);
    background: radial-gradient(circle at top, rgba(59,130,246,0.8), rgba(15,23,42,0.98));
    box-shadow:
        0 4px 14px rgba(15,23,42,0.7),
        0 0 8px rgba(59,130,246,0.45);
    color:#e5f0ff;
    transition:transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}
.landing .module-spoke:hover .module-icon{
    transform:translateY(-4px) scale(1.06);
    box-shadow:
        0 16px 40px rgba(15,23,42,1),
        0 0 22px rgba(59,130,246,1);
    border-color:rgba(129,140,248,1);
}
.landing .module-spoke .module-label{
    margin-top:8px;
    font-size:0.85rem;
    color:#cbd5f5;
}
.landing .module-spoke:hover .module-label{
    color:#e5e7eb;
}

/* Responsywność modułu hub+spokes – zmniejsz rozmiary na mniejszych ekranach */
@media (max-width: 768px){
    .landing .module-visualizer{
        width:min(320px, 100%);
        height:320px;
    }
    .landing .module-connections{
        width:320px;
        height:320px;
    }
    .landing .core-hub{
        width:130px;
        height:130px;
    }
    .landing .module-spoke{
        --distance:150px;
    }
    .landing .module-node{
        width:90px;
    }
    .landing .module-spoke .module-label{
        font-size:0.78rem;
    }
}
@media (max-width: 480px){
    .landing .module-visualizer{
        width:min(260px, 100%);
        height:260px;
    }
    .landing .module-connections{
        width:260px;
        height:260px;
    }
    .landing .core-hub{
        width:115px;
        height:115px;
    }
    .landing .module-spoke{
        --distance:125px;
    }
    .landing .module-node{
        width:80px;
    }
    .landing .module-spoke .module-label{
        font-size:0.72rem;
    }
}

@keyframes radarSpin{
    to { transform:rotate(360deg); }
}
.landing .angle-0{--angle:0deg}
.landing .angle-60{--angle:60deg}
.landing .angle-120{--angle:120deg}
.landing .angle-180{--angle:180deg}
.landing .angle-240{--angle:240deg}
.landing .angle-300{--angle:300deg}

/* Pricing lists */
.landing .pricing-card ul{list-style:none; margin:16px 0 0 0; padding:0; text-align:left}
.landing .pricing-card li{display:flex; align-items:center; gap:8px; margin-bottom:8px; color:var(--text-color)}
.landing .pricing-card .bi{color:var(--success-color)}

/* Icons pattern */
.landing .icon-xl{font-size:48px; color:var(--primary-color); display:inline-block; margin-bottom:16px}
.landing .feature-card .icon-xl{margin-bottom:12px}
.landing .audience-item .bi{font-size:20px; color:var(--success-color)}

/* Audience pills (horizontal on wide screens) */
.landing .audience-list{display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px}
.landing .audience-item{display:flex; gap:15px; align-items:center; padding:15px; background:var(--light-bg); border-radius:6px; border:1px solid var(--border-color); transition:box-shadow .2s ease, background .2s ease}
.landing .audience-item:hover{background:#fff; box-shadow:0 6px 14px rgba(0,0,0,.06)}
@media (min-width:992px){ .landing .audience-list{grid-template-columns:repeat(4,1fr);} }

/* Popular badge */
.landing .popular-badge{background:var(--primary-color); color:#fff; padding:5px 12px; border-radius:20px; font-size:.8rem; font-weight:600; display:inline-block; margin-bottom:10px; position:absolute; top:8px; left:50%; transform:translateX(-50%)}

/* Flattened content-body (no card frame) for sections with inner cards */
.landing .content-body.flat{background:transparent !important; border:none !important; box-shadow:none !important; padding:0 !important}
.landing .content-body.flat .content-body-header{border-bottom:none; padding:0 0 16px 0}

/* FAQ accordion – rotating plus icon (scoped to blog FAQ only) */
.faq-section .accordion-button::after{
  background-image:none;
  content:'+';
  font-weight:700;
  font-family:'Montserrat', Arial, sans-serif;
  color:var(--dark-blue);
  transform:rotate(0deg);
  transition:transform .2s ease;
  width:1.25rem; height:1.25rem;
  line-height:1.25rem; text-align:center;
}
.faq-section .accordion-button:not(.collapsed)::after{
  transform:rotate(45deg);
}

/* TOC left sticky */
.toc-left{position:sticky; top:100px; max-height:calc(100vh - 120px); overflow:auto; padding-right:6px}
.toc-left .text-muted{font-size:.75rem}
.toc-left .toc-item{margin:.15rem 0}
.toc-left .toc-item.toc-h3{margin-left:10px}
.toc-left .toc-link{display:block; padding:.1rem .15rem; border-radius:6px; color:var(--text-color); text-decoration:none; font-size:.85rem; line-height:1.15}
.toc-left .toc-link:hover{background:#f5f8ff; color:var(--primary-color)}
.toc-left .toc-link.active{background:#eef2ff; color:#2f6feb; font-weight:600}

/* Highlight active content section */
.article-content .section-active{scroll-margin-top: 120px; outline: 0;}
.article-content .section-active{position:relative}
.article-content .section-active::before{content:''; position:absolute; left:-12px; top:0; bottom:0; width:3px; background:#2f6feb; border-radius:2px}

/* Related posts card clamp */
.line-clamp-3{display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden}

/* Post cards thumbnails */
.post-card .thumb{position:relative; width:100%; aspect-ratio:16/9; overflow:hidden; border-radius:8px; background:#e9ecef}
.post-card .thumb img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block}

/* ========== ENTERPRISE DARK THEME (wzorowane na index(2).htm) ========== */

/* Font smoothing - using local Inter + JetBrains Mono from vendor/google-fonts */
body, .landing {
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Monospace font for tech elements */
.mono-tech, code, pre, .mockup-topbar, .trust-label, .card-module, .card-metrics,
.timeline-item, .industry-badge, .step-number, .nav-link-secondary, .brand-subtitle {
    font-family: 'JetBrains Mono', 'Courier New', monospace !important;
}

/* Hero Section - dokładnie jak wzorzec */
.landing .landing-intro.bg-light {
    background: radial-gradient(circle at top right, #1e293b 0%, #0f172a 60%) !important;
    position: relative !important;
    overflow-x: hidden !important;  /* odetnij pseudo-element / makietę w osi X, bez paska poziomego */
    overflow-y: hidden !important;  /* mockup nie „wychodzi” pod kolejną sekcję – brak efektu osobnego „okienka” */
    padding: 8rem 0 5rem !important;
    color: #f8fafc !important;
}

/* Glow effect - dokładnie jak wzorzec */
.landing .landing-intro::before {
    content: '';
    position: absolute;
    width: 600px;
    height: 600px;
    background: #3b82f6;
    filter: blur(150px);
    opacity: 0.15;
    top: -200px;
    right: -100px;
    border-radius: 50%;
    z-index: 0;
}

.landing .landing-intro .container {
    position: relative;
    z-index: 1;
}

.landing .landing-intro .row {
    align-items: center;
}

.landing .landing-intro .col-lg-5,
.landing .landing-intro .col-lg-7 {
    position: relative;
    z-index: 1;
}

/* Hero Title - lżejszy font */
.landing .landing-intro h1,
.landing .landing-intro .heading-muted {
    font-size: 3.5rem !important;
    font-weight: 600 !important; /* Semibold zamiast 800 */
    line-height: 1.1 !important;
    background: linear-gradient(to right, #fff, #94a3b8) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    margin-bottom: 1.5rem !important;
}

/* Hero text */
.landing .landing-intro p,
.landing .landing-intro .text-lg {
    color: #cbd5e1 !important;
    font-weight: 300 !important;
    font-size: 1.1rem !important;
    line-height: 1.7 !important;
}

.landing .landing-intro .small.text-muted {
    color: #94a3b8 !important;
}

/* Mockup - wyjeżdżający za hero (złamanie schematu) */
.landing .landing-intro .col-lg-7 {
    perspective: 500px;
    position: relative;
}

.landing .landing-intro .col-lg-7 .pb-3 {
    background: rgba(30, 41, 59, 0.6);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 12px;
    box-shadow: 0 28px 70px -18px rgba(0,0,0,0.7);
    /* Lekkie przesunięcie i perspektywa, ale w obrębie hero – bez wrażenia osobnego „okna"/iframe */
    transform: rotateY(-5deg) rotateX(5deg) translateY(24px) scale(1.05);
    transition: transform 0.5s ease;
    padding: 0 !important; /* zrzut ma wypełniać cały box */
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #64748b;
    position: relative;
    z-index: 20; /* Nad następną sekcją */
}

.landing .landing-intro .col-lg-7 .pb-3:hover {
    transform: rotateY(0) rotateX(0) translateY(18px) scale(1.05);
}

/* Obraz wypełnia cały box mockupu */
.landing .landing-intro .col-lg-7 .pb-3 img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 12px;
}

/* Dodaj padding-top do następnej sekcji, żeby nie nachodzić na tekst */
.landing .landing-intro + section,
.landing .landing-intro + .trust-bar,
.landing #latest-posts {
    padding-top: 3.5rem !important;
}

/* Wymuś Inter dla WSZYSTKIEGO w landing */
.landing,
.landing * {
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif !important;
}

/* Ogólna typografia - lekka (nadpisz Montserrat z linii 7-8) */
.landing h1, 
.landing h2, 
.landing h3,
.landing h4,
.landing h5,
.landing h6,
.landing .heading-muted {
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", sans-serif !important;
    font-weight: 500 !important; /* Medium */
    color: #0f172a !important;
    letter-spacing: -0.02em !important;
}

.landing h1 {
    font-weight: 600 !important; /* Semibold dla H1 */
    font-size: 2.8rem !important;
}

.landing h2 {
    font-size: 2rem !important;
}

.landing h3 {
    font-size: 1.25rem !important;
}

/* Body text - light weight */
.landing p, 
.landing .text-muted, 
.landing li,
.landing .card-text,
.landing span,
.landing div {
    font-weight: 400 !important; /* Regular */
}

/* Specjalnie lekki tekst dla opisów */
.landing p.text-muted,
.landing .card-text {
    font-weight: 300 !important; /* Light */
    color: #64748b !important;
}

/* Karty - subtelne */
.landing .card {
    box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important;
    border: 1px solid #e2e8f0 !important;
    transition: transform 0.2s, box-shadow 0.2s;
}
.landing .card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 16px rgba(0,0,0,0.12) !important;
}

/* Final CTA - białe nagłówki */
.landing .final-cta h2 {
    color: #ffffff !important;
}

/* Usuń białą przerwę */
body:has(.landing) .main-content {
    padding: 0 !important;
    margin: 0 !important;
}
.landing {
    margin-bottom: 0 !important;
}

/* ========================================================================
   ENTERPRISE CINEMATIC LANDING (React Project Style)
   ======================================================================== */

/* ============================================
   CINEMATIC BASE COMPONENTS (Reusable)
   ============================================ */

/* --- Typography --- */
.mono-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: #64748b;
}

.mono-label-cyan {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: #06b6d4;
}

/* --- Form Inputs --- */
.cinematic-input {
    background-color: #0b1221;
    border: 1px solid #1e293b;
    color: #fff;
    padding: 0.75rem 1rem;
    font-size: 14px;
    border-radius: 2px;
    transition: all 0.3s ease;
    width: 100%;
}

.cinematic-input:focus {
    border-color: #06b6d4;
    box-shadow: 0 0 0 1px rgba(6, 182, 212, 0.3);
    outline: none;
    background-color: #0f172a;
}

.cinematic-input::placeholder {
    color: #475569;
}

/* --- Buttons --- */
.cinematic-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.5rem;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: none;
    border-radius: 2px;
    cursor: pointer;
    text-decoration: none !important;
    transition: all 0.2s;
}

.cinematic-btn-primary {
    background: #06b6d4;
    color: #000;
    box-shadow: 0 0 20px rgba(6, 182, 212, 0.2);
}

.cinematic-btn-primary:hover {
    background: #22d3ee;
    color: #000;
    transform: translateY(-1px);
}

.cinematic-btn-outline {
    background: transparent;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.cinematic-btn-outline:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.3);
    color: #fff;
}

/* --- Cards --- */
.cinematic-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    padding: 1.5rem;
    border-radius: 2px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.cinematic-card-dark {
    background: rgba(15, 23, 42, 0.8);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1.5rem;
    border-radius: 2px;
}

/* --- Glass Panel --- */
.cinematic-glass {
    background: rgba(15, 23, 42, 0.6);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 0 0 1px rgba(0,0,0,0.1), 0 40px 80px -20px rgba(0,0,0,0.6);
}

/* --- Alerts --- */
.cinematic-alert {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    border-radius: 2px;
    font-size: 14px;
}

.cinematic-alert-success {
    background: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.3);
    color: #10b981;
}

.cinematic-alert-error {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #ef4444;
}

/* --- Grid Pattern Background --- */
.cinematic-grid-bg {
    background: linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
                linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 40px 40px;
}

/* === GLOBAL LANDING OVERRIDES === */
body.landing-page {
    background-color: #020408 !important;
    color: #e2e8f0;
    overflow-x: hidden;
}

/* Rich text typography (legal + CMS content) – niezależne od bloków JSON */
.rich-text-content h2,
.legal-content h2{
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 2rem 0 0.75rem;
}
.rich-text-content h3,
.legal-content h3{
    font-weight: 700;
    letter-spacing: -0.01em;
    margin: 1.5rem 0 0.5rem;
}
.rich-text-content p,
.legal-content p{
    line-height: 1.75;
    margin: 0 0 0.9rem;
}
.rich-text-content a,
.legal-content a{
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
}
.rich-text-content a:hover,
.legal-content a:hover{
    opacity: 0.9;
}

/* === PRODUCT HERO (1:1 z ss-produkt.html, DOKŁADNIE Tailwind) === */
.product-hero-prototype{
    position: relative;
    padding-top: 6rem;      /* pt-24 */
    padding-bottom: 8rem;   /* pb-32 */
    overflow: hidden;
    background: #020408;
}
.product-hero-glow{
    position:absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 1000px;
    height: 600px;
    background: rgba(6,182,212,0.05);
    filter: blur(120px);
    border-radius: 9999px;
    pointer-events:none;
}
.product-hero-grid{
    position:absolute;
    inset:0;
    background: linear-gradient(to right, rgba(255,255,255,0.05) 1px, transparent 1px),
                linear-gradient(to bottom, rgba(255,255,255,0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: .20;
    pointer-events:none;
}
.product-hero-container{
    max-width: 1440px;     /* max-w-[1440px] */
    margin: 0 auto;        /* mx-auto */
    padding: 0 1.5rem;     /* px-6 */
    position: relative;
    z-index: 10;           /* z-10 */
}
.product-hero-head{
    text-align: center;    /* text-center */
    max-width: 56rem;      /* max-w-4xl */
    margin: 0 auto 4rem auto; /* mx-auto mb-16 */
}
.product-hero-badge{
    display:inline-flex;   /* inline-flex */
    align-items:center;    /* items-center */
    gap:.5rem;             /* gap-2 */
    padding:.25rem .75rem; /* px-3 py-1 */
    border-radius: 4px;    /* rounded */
    border: 1px solid rgba(6,182,212,0.30); /* border-neon-cyan/30 */
    background: rgba(6,182,212,0.10);       /* bg-neon-cyan/10 */
    color:#06b6d4;         /* text-neon-cyan */
    font-family: 'JetBrains Mono', monospace !important; /* font-mono */
    font-size: 10px;       /* text-[10px] */
    text-transform: uppercase; /* uppercase */
    letter-spacing: .16em; /* tracking-widest */
    margin-bottom: 1.5rem; /* mb-6 */
}
.product-hero-title{
    font-size: 3rem;       /* text-5xl */
    font-weight: 700;      /* font-bold */
    color:#fff;            /* text-white */
    margin-bottom: 1.5rem; /* mb-6 */
    letter-spacing: -.025em; /* tracking-tight */
    line-height: 1;        /* leading-none */
}
@media (min-width: 768px) {
    .product-hero-title {
        font-size: 4.5rem; /* md:text-7xl */
    }
}
.product-hero-title-gradient{
    color: transparent;    /* text-transparent */
    background: linear-gradient(to right, #06b6d4, #3b82f6); /* bg-gradient-to-r from-neon-cyan to-blue-500 */
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.product-hero-subtitle{
    font-size: 1.125rem;   /* text-lg */
    color:#94a3b8;         /* text-slate-400 */
    max-width: 42rem;      /* max-w-2xl */
    margin: 0 auto;        /* mx-auto */
    line-height: 1.75;     /* leading-relaxed */
    font-weight: 300;      /* font-light */
}

/* Blog single post has light gray background (concrete-50) */
body.landing-page:has(.blog-content-wrapper) {
    background-color: #f8fafc !important;
    color: #1e293b;
}

body.landing-page:has(.blog-content-wrapper) .blog-content-wrapper {
    background-color: #f8fafc;
}

.landing-cinematic {
    background-color: #020408;
    color: #e2e8f0;
}

/* Hide old header/lang-bar for cinematic design */
.landing-cinematic .lang-bar,
.landing-cinematic .public-header,
.landing-cinematic + .lang-bar,
body:has(.landing-cinematic) .lang-bar,
body:has(.landing-cinematic) .public-header {
    display: none !important;
}

/* === CINEMATIC BACKGROUND LAYERS === */
.cinematic-bg-container {
    position: fixed;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

.cinematic-image {
    /* Disabled - using pure gradient background instead */
    display: none;
    /*
    width: 100%;
    height: 100%;
    background-image: url('../images/landing-screenshot.png');
    background-size: cover;
    background-position: center;
    opacity: 0.35;
    filter: saturate(0) contrast(1.2) brightness(0.7);
    animation: bgPan 60s linear infinite alternate;
    */
}

.vignette-heavy {
    position: fixed;
    inset: 0;
    background: radial-gradient(circle at 50% 50%, transparent 0%, #020408 90%);
    z-index: 0;
    pointer-events: none;
}

.grid-pattern-overlay {
    position: fixed;
    inset: 0;
    background-image: 
        linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 60px 60px;
    opacity: 0.1;
    z-index: 0;
    pointer-events: none;
}

/* === ANIMATIONS === */
@keyframes bgPan {
    0% { transform: scale(1); }
    100% { transform: scale(1.15); }
}

@keyframes bootUp {
    0% { opacity: 0; filter: blur(10px); }
    100% { opacity: 1; filter: blur(0); }
}

@keyframes fadeSlideUp {
    0% { opacity: 0; transform: translateY(30px); }
    100% { opacity: 1; transform: translateY(0); }
}

@keyframes reveal3d {
    0% { opacity: 0; transform: perspective(1000px) rotateY(15deg) translateX(100px) scale(0.9); }
    100% { opacity: 1; transform: perspective(1000px) rotateY(0deg) translateX(0) scale(1); }
}

@keyframes scanBeam {
    0% { top: -5%; opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { top: 105%; opacity: 0; }
}

.animate-boot-sequence { animation: bootUp 1.5s cubic-bezier(0.22, 1, 0.36, 1) forwards; }
.animate-fade-slide-up { opacity: 0; animation: fadeSlideUp 0.8s ease-out forwards; }
.animate-reveal-3d { opacity: 0; animation: reveal3d 1.2s cubic-bezier(0.16, 1, 0.3, 1) 0.3s forwards; }

/* === TECH NAVBAR === */
.tech-navbar {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 50;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    background: rgba(2,4,8,0.9);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    animation: bootUp 1.5s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.tech-navbar .nav-inner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Brand */
.tech-navbar .brand-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.3s;
}

.tech-navbar .brand-link:hover {
    transform: scale(1.02);
}

.tech-navbar .brand-icon {
    position: relative;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.tech-navbar .brand-icon .icon-bg {
    position: absolute;
    inset: 0;
    background: rgba(6,182,212,0.1);
    border: 1px solid rgba(6,182,212,0.3);
    transform: rotate(45deg);
    transition: transform 0.5s;
}

.tech-navbar .brand-link:hover .icon-bg {
    transform: rotate(0deg);
}

.tech-navbar .brand-icon i {
    position: relative;
    z-index: 10;
    color: #06b6d4;
    font-size: 0.875rem;
}

.tech-navbar .brand-text {
    display: flex;
    flex-direction: column;
    line-height: 1;
}

.tech-navbar .brand-name {
    font-size: 1rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.02em;
}

.tech-navbar .brand-name .accent {
    color: #06b6d4;
}

.tech-navbar .brand-subtitle {
    font-size: 8px;
    color: #64748b;
    font-family: 'JetBrains Mono', monospace !important;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-top: 4px;
}

/* Desktop Nav */
.tech-navbar .nav-menu {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0;
    align-items: center;
    height: 100%;
    gap: 1.5rem;
}

@media (min-width: 1024px) {
    .tech-navbar .nav-menu {
        display: flex;
    }
}

.tech-navbar .nav-menu li {
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
}

.tech-navbar .nav-menu a {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: #94a3b8;
    text-decoration: none;
    transition: color 0.3s;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    padding: 2rem 0;
}

.tech-navbar .nav-menu a:hover {
    color: #06b6d4;
}

/* Nav Actions */
.tech-navbar .nav-actions {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.tech-navbar .nav-link-secondary {
    font-size: 0.75rem;
    color: #94a3b8;
    text-decoration: none;
    font-weight: 500;
    font-family: 'JetBrains Mono', monospace !important;
    letter-spacing: 0.05em;
    transition: color 0.3s;
}

.tech-navbar .nav-link-secondary:hover {
    color: #fff;
}

.tech-navbar .nav-btn-primary {
    position: relative;
    padding: 0.625rem 1.5rem;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    overflow: hidden;
    transition: all 0.3s;
    text-decoration: none;
    display: inline-block;
}

.tech-navbar .nav-btn-primary span {
    position: relative;
    z-index: 10;
}

.tech-navbar .nav-btn-primary .btn-glow {
    position: absolute;
    inset: 0;
    background: rgba(6,182,212,0.1);
    transform: translateY(100%);
    transition: transform 0.3s;
}

.tech-navbar .nav-btn-primary:hover {
    border-color: rgba(6,182,212,0.5);
    background: rgba(6,182,212,0.05);
    color: #fff;
}

.tech-navbar .nav-btn-primary:hover .btn-glow {
    transform: translateY(0);
}

/* === LANGUAGE SWITCHER (MATRIX STYLE) === */
.lang-switcher-matrix {
    position: relative;
    height: 40px;
    display: flex;
    align-items: center;
}

.lang-switcher-matrix .lang-trigger {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.75rem;
    color: #94a3b8;
    font-family: 'JetBrains Mono', monospace !important;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: transparent;
    border: none;
    cursor: pointer;
    transition: color 0.3s;
    padding: 0;
}

.lang-switcher-matrix .lang-trigger:hover {
    color: #fff;
}

.lang-switcher-matrix .lang-trigger .chevron {
    font-size: 8px;
    opacity: 0.5;
}

.lang-switcher-matrix .lang-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 1rem;
    width: 320px;
    background: rgba(11, 18, 33, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1.25rem;
    box-shadow: 0 0 50px -10px rgba(0, 0, 0, 0.8);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: all 0.3s ease;
    z-index: 100;
}

.lang-switcher-matrix:hover .lang-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.lang-switcher-matrix .lang-dropdown-label {
    display: block;
    font-size: 9px;
    font-family: 'JetBrains Mono', monospace !important;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.lang-switcher-matrix .lang-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.5rem;
}

.lang-switcher-matrix .lang-option {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 32px;
    font-size: 10px;
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace !important;
    color: #94a3b8;
    text-decoration: none;
    border: 1px solid transparent;
    border-radius: 2px;
    transition: all 0.2s;
}

.lang-switcher-matrix .lang-option:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
}

.lang-switcher-matrix .lang-option.active {
    color: #06b6d4;
    background: rgba(6, 182, 212, 0.1);
    border-color: rgba(6, 182, 212, 0.5);
}

/* === MEGA MENU === */
.tech-navbar .megamenu {
    opacity: 0;
    transform: translateY(10px) scale(0.98);
    pointer-events: none;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10px) scale(0.98);
    width: 900px;
    background: rgba(11,18,33,0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 2px;
    box-shadow: 0 50px 100px -20px rgba(0,0,0,0.8);
    overflow: hidden;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    z-index: 50;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.tech-navbar .nav-menu li:hover .megamenu {
    opacity: 1;
    transform: translateX(-50%) translateY(0) scale(1);
    pointer-events: auto;
}

.megamenu-col {
    padding: 2rem;
}

.megamenu-col-4 { grid-column: span 4; }
.megamenu-col-border { border-right: 1px solid rgba(255,255,255,0.05); }
.megamenu-col-dark { background: rgba(15,23,42,0.5); }
.megamenu-col-highlight {
    background: linear-gradient(to bottom right, rgba(6,182,212,0.1), transparent);
    position: relative;
    overflow: hidden;
}

.megamenu-label {
    font-size: 9px;
    font-family: 'JetBrains Mono', monospace !important;
    color: #06b6d4;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 1.5rem;
    display: block;
}

.megamenu-label.muted { color: #64748b; }

.megamenu-item {
    display: block;
    padding: 0.75rem;
    margin: 0 -0.75rem;
    border-radius: 4px;
    text-decoration: none;
    transition: background 0.2s;
}

.megamenu-item:hover {
    background: rgba(255,255,255,0.05);
}

.megamenu-item-title {
    font-size: 0.875rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.25rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.megamenu-item-title i {
    color: #06b6d4;
    opacity: 0.5;
    transition: opacity 0.2s;
}

.megamenu-item:hover .megamenu-item-title i {
    opacity: 1;
}

.megamenu-item-desc {
    font-size: 10px;
    color: #64748b;
}

.megamenu-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: #cbd5e1;
    text-decoration: none;
    padding: 0.5rem 0;
    transition: all 0.2s;
}

.megamenu-link:hover {
    color: #fff;
    transform: translateX(4px);
}

.megamenu-link i {
    color: #475569;
}

/* === HERO SECTION (CINEMATIC) === */
.hero-cinematic {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding-top: 8rem;
    padding-bottom: 5rem;
    z-index: 10;
    overflow: hidden;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

.hero-cinematic .hero-container {
    max-width: 1440px;
    width: 100%;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.hero-cinematic .hero-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4rem;
    align-items: center;
}

@media (min-width: 1024px) {
    .hero-cinematic .hero-grid {
        grid-template-columns: 5fr 7fr;
    }
}

/* Hero Content */
.hero-cinematic .hero-content {
    position: relative;
    z-index: 20;
}

.hero-cinematic .hero-badge {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 2rem;
}

.hero-cinematic .hero-badge-line {
    height: 1px;
    width: 2rem;
    background: #06b6d4;
}

.hero-cinematic .hero-badge-text {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace !important;
    color: #06b6d4;
    text-transform: uppercase;
    letter-spacing: 0.15em;
}

.hero-cinematic .hero-title {
    font-size: clamp(2.5rem, 6vw, 5rem);
    font-weight: 700;
    color: #fff;
    line-height: 0.95;
    letter-spacing: -0.04em;
    margin-bottom: 2rem;
}

.hero-cinematic .hero-title .gradient-text {
    background: linear-gradient(to right, #06b6d4, #60a5fa, #fff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero-cinematic .hero-desc {
    font-size: 1.125rem;
    color: #94a3b8;
    line-height: 1.7;
    font-weight: 300;
    max-width: 32rem;
    border-left: 2px solid rgba(255,255,255,0.1);
    padding-left: 1.5rem;
    margin-bottom: 3rem;
}

.hero-cinematic .hero-desc .highlight {
    color: #fff;
    font-weight: 500;
}

/* Hero CTA Buttons */
.hero-cinematic .hero-actions {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

@media (min-width: 640px) {
    .hero-cinematic .hero-actions {
        flex-direction: row;
    }
}

.hero-cinematic .btn-hero-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 1rem 2rem;
    background: #06b6d4;
    color: #020408;
    font-weight: 700;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    transition: all 0.3s;
    box-shadow: 0 0 40px rgba(6,182,212,0.3);
    white-space: nowrap;
}

.hero-cinematic .btn-hero-primary:hover {
    background: #22d3ee;
    color: #020408;
    transform: translateY(-2px);
}

.hero-cinematic .btn-hero-primary i {
    transition: transform 0.3s;
}

.hero-cinematic .btn-hero-primary:hover i {
    transform: translateX(4px);
}

.hero-cinematic .btn-hero-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 1rem 2rem;
    border: 1px solid rgba(255,255,255,0.2);
    color: #fff;
    font-size: 0.75rem;
    font-family: 'JetBrains Mono', monospace !important;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    text-decoration: none;
    transition: all 0.3s;
    white-space: nowrap;
}

.hero-cinematic .btn-hero-secondary:hover {
    background: rgba(255,255,255,0.05);
    color: #fff;
}

/* Hero Interface Mockup */
.hero-cinematic .hero-mockup {
    position: relative;
    perspective: 2500px;
}

.hero-cinematic .mockup-panel {
    position: relative;
    background: rgba(15, 23, 42, 0.6);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 0 0 1px rgba(0,0,0,0.1), 0 40px 80px -20px rgba(0,0,0,0.6);
    border-radius: 4px;
    overflow: hidden;
}

.hero-cinematic .mockup-panel::before,
.hero-cinematic .mockup-panel::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    border-color: rgba(6, 182, 212, 0.3);
    border-style: solid;
    border-width: 0;
    transition: border-color 0.3s;
}

.hero-cinematic .mockup-panel::before {
    top: -1px;
    left: -1px;
    border-top-width: 2px;
    border-left-width: 2px;
}

.hero-cinematic .mockup-panel::after {
    bottom: -1px;
    right: -1px;
    border-bottom-width: 2px;
    border-right-width: 2px;
}

.hero-cinematic .mockup-panel:hover::before,
.hero-cinematic .mockup-panel:hover::after {
    border-color: #06b6d4;
}

.hero-cinematic .mockup-topbar {
    height: 36px;
    background: #050b14;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 1rem;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 9px;
    color: #64748b;
}

/* Product/hero mockup helpers (no inline styles; CSP-safe) */
.mockup-topbar-left{display:flex;align-items:center;gap:1rem}
.mockup-dots{display:flex;gap:4px}
.mockup-dot{width:4px;height:4px;background:#475569;border-radius:50%}

/* Hotspot positions (replace inline style=top/left) */
.hero-cinematic .hotspot.pos-1{top:35%;left:25%}
.hero-cinematic .hotspot.pos-2{top:25%;right:35%}
.hero-cinematic .hotspot.pos-3{bottom:20%;left:40%}
.hero-cinematic .hotspot-tooltip.hotspot-tooltip-right{left:auto;right:2rem;text-align:right}

.hero-cinematic .mockup-topbar .status-active {
    color: #06b6d4;
}

.hero-cinematic .mockup-content {
    position: relative;
    background: #000;
    aspect-ratio: 16/10;
    overflow: hidden;
}

.hero-cinematic .mockup-content img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.8;
    transition: opacity 0.7s;
}

.hero-cinematic .mockup-panel:hover .mockup-content img {
    opacity: 1;
}

.hero-cinematic .mockup-grid-overlay {
    position: absolute;
    inset: 0;
    background-image: 
        linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 20px 20px;
    opacity: 0.2;
    pointer-events: none;
}

.hero-cinematic .scan-beam {
    position: absolute;
    width: 100%;
    height: 150px;
    background: linear-gradient(to bottom, transparent, rgba(6, 182, 212, 0.2), transparent);
    animation: scanBeam 4s cubic-bezier(0.4, 0, 0.2, 1) infinite;
    pointer-events: none;
}

/* Hotspot */
.hero-cinematic .hotspot {
    position: absolute;
    cursor: pointer;
}

.hero-cinematic .hotspot-dot {
    width: 12px;
    height: 12px;
    background: #f43f5e;
    border-radius: 50%;
    box-shadow: 0 0 15px #f43f5e;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.2); opacity: 0.8; }
}

.hero-cinematic .hotspot-tooltip {
    position: absolute;
    left: 2rem;
    top: 0;
    width: 12rem;
    background: rgba(5,11,20,0.95);
    border: 1px solid rgba(255,255,255,0.1);
    padding: 0.75rem;
    opacity: 0;
    transition: opacity 0.3s;
    backdrop-filter: blur(10px);
}

.hero-cinematic .hotspot:hover .hotspot-tooltip {
    opacity: 1;
}

.hero-cinematic .hotspot-label {
    font-size: 8px;
    font-family: 'JetBrains Mono', monospace !important;
    color: #f43f5e;
    text-transform: uppercase;
    margin-bottom: 0.25rem;
}

.hero-cinematic .hotspot-title {
    font-size: 0.75rem;
    color: #fff;
    font-weight: 700;
}

.hero-cinematic .hotspot-desc {
    font-size: 9px;
    color: #94a3b8;
    margin-top: 0.25rem;
}

/* === TRUST SECTION === */
.trust-section {
    padding: 3rem 0;
    background: #03060d;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    position: relative;
    z-index: 20;
}

.trust-section .trust-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
    text-align: center;
}

.trust-section .trust-label {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace !important;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 2rem;
}

.trust-section .trust-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 3rem;
    opacity: 0.6;
    transition: opacity 0.5s;
}

.trust-section:hover .trust-grid {
    opacity: 1;
}

.trust-section .trust-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: #fff;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 1.25rem;
    font-weight: 700;
}

/* === BENEFITS SECTION (LIGHT) === */
.benefits-section {
    padding: 8rem 0;
    background: #f1f5f9;
    position: relative;
    z-index: 20;
}

.benefits-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: 
        linear-gradient(to right, rgba(15, 23, 42, 0.03) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(15, 23, 42, 0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

.benefits-section .section-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 10;
}

/* Section Header */
.section-header {
    margin-bottom: 5rem;
}

.section-header.text-left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.section-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 0.75rem;
    display: block;
}

.section-label.blue { color: #3b82f6; }
.section-label.cyan { color: #06b6d4; }

.section-title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    line-height: 1.2;
}

.section-title.dark { color: #0f172a; }
.section-title.light { color: #fff; }

.section-title .muted { color: #cbd5e1; }

/* Concrete Cards */
.benefits-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2rem;
}

.concrete-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    padding: 2rem;
    border-radius: 4px;
    transition: all 0.3s;
}

.concrete-card:hover {
    border-color: #06b6d4;
    transform: translateY(-4px);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

.concrete-card.featured {
    border-top: 4px solid #10b981;
}

.card-header-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 2rem;
}

.card-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    border-radius: 4px;
}

.card-icon.blue { background: #eff6ff; color: #3b82f6; }
.card-icon.green { background: #ecfdf5; color: #10b981; }
.card-icon.cyan { background: #ecfeff; color: #06b6d4; }

.card-module {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace !important;
    color: #cbd5e1;
}

.card-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 0.75rem;
}

.card-text {
    font-size: 0.875rem;
    color: #475569;
    line-height: 1.6;
    margin-bottom: 2rem;
}

/* Card Metrics */
.card-metrics {
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 10px;
}

.metric-row {
    margin-bottom: 0.75rem;
}

.metric-label {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.25rem;
    color: #64748b;
}

.metric-label.highlight {
    color: #0f172a;
    font-weight: 700;
}

.metric-label .value { color: #3b82f6; }

.metric-bar {
    width: 100%;
    height: 4px;
    background: #e2e8f0;
    border-radius: 2px;
    overflow: hidden;
}

.metric-fill {
    height: 100%;
    border-radius: 2px;
}

.metric-fill.gray { background: #cbd5e1; }
.metric-fill.blue { background: #3b82f6; }

/* Card File */
.card-file {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    padding: 0.75rem;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.file-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.file-info i {
    color: #cbd5e1;
    font-size: 1.25rem;
}

.file-name {
    font-size: 0.75rem;
    color: #0f172a;
    font-weight: 700;
}

.file-langs {
    font-size: 8px;
    color: #cbd5e1;
}

.file-badge {
    color: #10b981;
    font-size: 0.75rem;
    font-weight: 700;
}

/* Card Timeline */
.card-timeline {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.timeline-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 10px;
    color: #cbd5e1;
}

.timeline-item.active {
    color: #475569;
}

.timeline-bar {
    width: 4px;
    height: 8px;
    background: #e2e8f0;
}

.timeline-item.active .timeline-bar {
    background: #06b6d4;
}

.timeline-time {
    font-weight: 700;
}

/* === INDUSTRIES SECTION === */
.industries-section {
    padding: 6rem 0;
    background: #fff;
    border-top: 1px solid #e2e8f0;
    position: relative;
    z-index: 10;
}

.industries-section .section-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.industries-section .section-header {
    text-align: center;
    margin-bottom: 5rem;
}

.industries-section .section-desc {
    color: #475569;
    margin-top: 1rem;
    max-width: 42rem;
    margin-left: auto;
    margin-right: auto;
}

.industries-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
}

/* Grid 6 kafelków - 3 kolumny na desktop */
.industries-grid-6 {
    grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1024px) {
    .industries-grid-6 {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 640px) {
    .industries-grid-6 {
        grid-template-columns: 1fr;
    }
}

.industry-card {
    border: 1px solid #e2e8f0;
    padding: 1.5rem;
    transition: all 0.3s;
    background: #fff;
}

.industry-card:hover {
    border-color: #06b6d4;
    box-shadow: 0 4px 20px rgba(6, 182, 212, 0.1);
}

/* Nowy styl ikony (bez badge) */
.industry-icon {
    margin-bottom: 1rem;
}

.industry-icon i {
    font-size: 2rem;
    color: #94a3b8;
    transition: color 0.3s;
}

.industry-card:hover .industry-icon i {
    color: #06b6d4;
}

/* Legacy: industry-header (dla kompatybilności) */
.industry-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.industry-header i {
    font-size: 2rem;
    color: #cbd5e1;
    transition: color 0.3s;
}

.industry-card:hover .industry-header i {
    color: #06b6d4;
}

.industry-badge {
    font-size: 9px;
    font-family: 'JetBrains Mono', monospace !important;
    border: 1px solid #e2e8f0;
    padding: 0.25rem 0.5rem;
    border-radius: 2px;
    color: #475569;
}

.industry-title {
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 0.5rem;
    font-size: 1rem;
}

.industry-text {
    font-size: 0.875rem;
    color: #64748b;
    line-height: 1.6;
}

/* === PROCESS SECTION (DARK) === */
.process-section {
    padding: 8rem 0;
    background: #0f172a;
    position: relative;
    overflow: hidden;
    z-index: 20;
    border-top: 1px solid rgba(255,255,255,0.05);
}

.process-section .process-bg {
    position: absolute;
    inset: 0;
    background-image: 
        linear-gradient(to right, #1e293b 1px, transparent 1px),
        linear-gradient(to bottom, #1e293b 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.2;
}

.process-section .process-gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, #0f172a, transparent, #0f172a);
}

.process-section .section-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 10;
}

.process-section .section-header {
    text-align: center;
    margin-bottom: 6rem;
}

.process-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2rem;
}

.process-line {
    display: none;
}

@media (min-width: 768px) {
    .process-line {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 1px;
        background: linear-gradient(to right, transparent, rgba(255,255,255,0.2), transparent);
        transform: translateY(24px);
    }
}

.process-step {
    position: relative;
}

.process-glow {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle, rgba(6,182,212,0.05), transparent);
    opacity: 0;
    transition: opacity 0.5s;
    pointer-events: none;
}

.process-glow.green { background: radial-gradient(circle, rgba(16,185,129,0.05), transparent); }
.process-glow.blue { background: radial-gradient(circle, rgba(59,130,246,0.05), transparent); }

.process-step:hover .process-glow {
    opacity: 1;
}

.process-card {
    background: #0b1221;
    border: 1px solid rgba(255,255,255,0.1);
    padding: 2rem;
    padding-top: 3rem;
    border-radius: 4px;
    position: relative;
    transition: all 0.3s;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.process-card:hover {
    border-color: rgba(6,182,212,0.5);
}

.step-number {
    position: absolute;
    top: -24px;
    width: 48px;
    height: 48px;
    background: #0b1221;
    border: 1px solid rgba(255,255,255,0.2);
    color: #06b6d4;
    font-family: 'JetBrains Mono', monospace !important;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    box-shadow: 0 0 15px rgba(6,182,212,0.2);
    transition: all 0.3s;
    z-index: 20;
}

.step-number.green { color: #10b981; box-shadow: 0 0 15px rgba(16,185,129,0.2); }
.step-number.blue { color: #3b82f6; box-shadow: 0 0 15px rgba(59,130,246,0.2); }

.process-card:hover .step-number {
    border-color: #06b6d4;
    transform: scale(1.1);
}

.step-icon {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 50%;
    color: #06b6d4;
    font-size: 2rem;
    margin-bottom: 1.5rem;
    transition: all 0.3s;
}

.step-icon.green { color: #10b981; }
.step-icon.blue { color: #3b82f6; }

.process-card:hover .step-icon {
    background: rgba(6,182,212,0.2);
    color: #fff;
}

.step-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.75rem;
    transition: color 0.3s;
}

.process-card:hover .step-title {
    color: #06b6d4;
}

.step-text {
    font-size: 0.875rem;
    color: #94a3b8;
    line-height: 1.6;
}

.step-corner {
    position: absolute;
    width: 12px;
    height: 12px;
    border-color: rgba(255,255,255,0.2);
    border-style: solid;
    border-width: 0;
    transition: border-color 0.3s;
}

.step-corner-tl { top: 0; left: 0; border-top-width: 1px; border-left-width: 1px; }
.step-corner-br { bottom: 0; right: 0; border-bottom-width: 1px; border-right-width: 1px; }

.process-card:hover .step-corner {
    border-color: #06b6d4;
}

/* === PRICING SECTION (NEW) === */
.pricing-section-new {
    padding: 8rem 0;
    background: #f8fafc;
    position: relative;
    z-index: 20;
    border-top: 1px solid #e2e8f0;
}

.pricing-section-new .section-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.pricing-section-new .section-header {
    text-align: center;
    margin-bottom: 4rem;
}

.pricing-section-new .section-desc {
    color: #475569;
    margin-top: 1rem;
}

.pricing-grid-new {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
    max-width: 64rem;
    margin: 0 auto;
}

.pricing-card-new {
    background: #fff;
    padding: 2rem;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    text-align: center;
    transition: all 0.3s;
    display: flex;
    flex-direction: column;
}

.pricing-card-new:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 28px rgba(0,0,0,0.08);
}

.pricing-card-new.featured {
    background: #0f172a;
    color: #fff;
    border: 2px solid #0f172a;
    box-shadow: 0 16px 36px rgba(15,23,42,0.15);
    transform: translateY(-4px);
    position: relative;
}

.pricing-card-new.featured::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: #06b6d4;
}

.featured-badge {
    background: #06b6d4;
    color: #020408;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    display: inline-block;
    margin-bottom: 0.5rem;
}

.pricing-name {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.pricing-card-new .pricing-name { color: #0f172a; }
.pricing-card-new.featured .pricing-name { color: #fff; }

.pricing-price {
    font-size: 2.5rem;
    font-weight: 700;
    margin: 1rem 0;
}

.pricing-card-new .pricing-price { color: #0f172a; }
.pricing-card-new.featured .pricing-price { color: #fff; }

.pricing-price span {
    font-size: 0.875rem;
    font-weight: 400;
    color: #64748b;
}

.pricing-card-new.featured .pricing-price span {
    color: #94a3b8;
}

.pricing-features {
    list-style: none;
    padding: 0;
    margin: 1.5rem 0;
    text-align: left;
    flex: 1;
}

.pricing-features li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    font-size: 0.875rem;
}

.pricing-card-new .pricing-features li { color: #475569; }
.pricing-card-new.featured .pricing-features li { color: #cbd5e1; }

.pricing-features i { color: #10b981; }
.pricing-card-new.featured .pricing-features i { color: #06b6d4; }

.pricing-btn {
    display: block;
    width: 100%;
    padding: 0.75rem;
    text-align: center;
    border: 1px solid #cbd5e1;
    border-radius: 4px;
    font-weight: 700;
    font-size: 0.875rem;
    color: #0f172a;
    text-decoration: none;
    transition: all 0.3s;
    margin-top: auto;
}

.pricing-btn:hover {
    background: #f8fafc;
    color: #0f172a;
}

.pricing-btn.primary {
    background: #06b6d4;
    color: #000;
    border-color: #06b6d4;
}

.pricing-btn.primary:hover {
    background: #0891b2;
    color: #000;
}

.pricing-desc {
    font-size: 0.875rem;
    color: #64748b;
    margin-bottom: 1rem;
    min-height: 2.5em;
}
.pricing-card-new.featured .pricing-desc {
    color: #94a3b8;
}

.pricing-compare {
    text-align: center;
    margin-top: 3rem;
}
.pricing-compare .compare-link {
    color: #06b6d4;
    font-weight: 500;
    text-decoration: none;
    transition: color 0.2s;
}
.pricing-compare .compare-link:hover {
    color: #0891b2;
    text-decoration: underline;
}

/* Trust bar audience style */
.trust-grid.trust-audience {
    gap: 0.4rem;
    flex-wrap: nowrap;
}
.trust-grid.trust-audience .trust-item {
    white-space: nowrap;
}
.trust-grid.trust-audience .trust-item span {
    font-size: 0.7rem;
}
.trust-separator {
    color: #64748b;
    font-size: 0.6rem;
    opacity: 0.5;
    flex-shrink: 0;
}
@media (max-width: 1100px) {
    .trust-grid.trust-audience {
        flex-wrap: wrap;
        justify-content: center;
        gap: 0.5rem 1rem;
    }
    .trust-separator { display: none; }
}
@media (max-width: 768px) {
    .trust-grid.trust-audience {
        flex-direction: column;
        gap: 0.75rem;
        align-items: center;
    }
}

/* === FINAL CTA SECTION (NEW) === */
.final-cta-new {
    padding: 8rem 0;
    background: #020408;
    position: relative;
    overflow: hidden;
}

.final-cta-new .cta-glow {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, rgba(6, 182, 212, 0.15) 0%, transparent 70%);
    z-index: 0;
    pointer-events: none;
}

.final-cta-new .cta-container {
    max-width: 56rem;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 10;
    text-align: center;
}

.final-cta-new .cta-title {
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.02em;
    margin-bottom: 2rem;
    line-height: 1.1;
}

.final-cta-new .cta-title .accent {
    color: #06b6d4;
}

.final-cta-new .cta-text {
    font-size: 1.125rem;
    color: #94a3b8;
    margin-bottom: 3rem;
    max-width: 32rem;
    margin-left: auto;
    margin-right: auto;
}

.final-cta-new .cta-actions {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    align-items: center;
}

@media (min-width: 640px) {
    .final-cta-new .cta-actions {
        flex-direction: row;
        justify-content: center;
    }
}

.final-cta-new .cta-btn {
    padding: 1.25rem 2.5rem;
    font-weight: 700;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: 4px;
    text-decoration: none;
    transition: all 0.3s;
}

.final-cta-new .cta-btn.primary {
    background: #06b6d4;
    color: #020408;
    box-shadow: 0 0 50px rgba(6,182,212,0.4);
}

.final-cta-new .cta-btn.primary:hover {
    background: #0891b2;
    box-shadow: 0 0 80px rgba(6,182,212,0.6);
    transform: translateY(-2px);
}

.final-cta-new .cta-btn.secondary {
    border: 1px solid rgba(255,255,255,0.2);
    color: #fff;
    background: transparent;
}

.final-cta-new .cta-btn.secondary:hover {
    background: rgba(255,255,255,0.05);
    color: #fff;
}

.final-cta-new .cta-badge {
    opacity: 0.5;
    margin-left: 0.5rem;
}

/* === FOOTER (NEW) === */
.footer-new {
    background: #020408;
    border-top: 1px solid rgba(255,255,255,0.1);
    padding: 5rem 0 2.5rem;
    position: relative;
    z-index: 20;
}

.footer-new .footer-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.footer-new .footer-grid {
    display: grid;
    grid-template-columns: 2fr repeat(3, 1fr);
    gap: 3rem;
    margin-bottom: 4rem;
}

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

.footer-new .footer-brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.footer-new .footer-brand-icon {
    position: relative;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.footer-new .footer-brand-icon .icon-bg {
    position: absolute;
    inset: 0;
    background: rgba(6, 182, 212, 0.1);
    border: 1px solid rgba(6, 182, 212, 0.3);
    transform: rotate(45deg);
}

.footer-new .footer-brand-icon i {
    position: relative;
    z-index: 1;
    color: #06b6d4;
    font-size: 14px;
}

.footer-new .footer-brand-text {
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.02em;
}

.footer-new .footer-brand-text .accent {
    color: #06b6d4;
}

.footer-new .footer-desc {
    font-size: 0.75rem;
    color: #64748b;
    line-height: 1.6;
}

.footer-new .footer-col-title {
    font-size: 0.875rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 1rem;
}

.footer-new .footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-new .footer-links li {
    margin-bottom: 0.5rem;
}

.footer-new .footer-links a {
    font-size: 0.75rem;
    color: #64748b;
    text-decoration: none;
    transition: color 0.2s;
}

.footer-new .footer-links a:hover {
    color: #06b6d4;
}

.footer-new .footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.05);
    padding-top: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
}

@media (min-width: 768px) {
    .footer-new .footer-bottom {
        flex-direction: row;
        justify-content: space-between;
    }
}

.footer-new .footer-copyright {
    font-size: 10px;
    color: #475569;
}

.footer-new .footer-legal {
    display: flex;
    gap: 1.5rem;
}

.footer-new .footer-legal a {
    font-size: 10px;
    color: #475569;
    text-decoration: none;
    transition: color 0.2s;
}

.footer-new .footer-legal a:hover {
    color: #94a3b8;
}

/* === BLOG SECTION === */
.blog-section {
    padding: 6rem 0;
    background: #f8fafc;
    position: relative;
    z-index: 20;
}

.blog-section .section-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.blog-section .section-header {
    text-align: center;
    margin-bottom: 4rem;
}

.blog-section .section-label {
    display: block;
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #3b82f6;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 0.75rem;
}

.blog-section .section-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 1rem;
}

.blog-section .section-subtitle {
    font-size: 1rem;
    color: #64748b;
    max-width: 600px;
    margin: 0 auto;
}

.blog-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 2rem;
}

@media (min-width: 768px) {
    .blog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .blog-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.blog-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    overflow: hidden;
    transition: all 0.3s ease;
}

.blog-card:hover {
    border-color: #06b6d4;
    transform: translateY(-4px);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

.blog-card-image {
    display: block;
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
}

.blog-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.blog-card:hover .blog-card-image img {
    transform: scale(1.05);
}

.blog-card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.3) 0%, transparent 50%);
    opacity: 0;
    transition: opacity 0.3s;
}

.blog-card:hover .blog-card-overlay {
    opacity: 1;
}

.blog-card-content {
    padding: 1.5rem;
}

.blog-card-meta {
    margin-bottom: 0.75rem;
}

.blog-card-date {
    font-size: 11px;
    font-family: 'JetBrains Mono', monospace;
    color: #94a3b8;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.blog-card-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 0.75rem;
    line-height: 1.4;
}

.blog-card-title a {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s;
}

.blog-card-title a:hover {
    color: #06b6d4;
}

.blog-card-excerpt {
    font-size: 0.875rem;
    color: #64748b;
    line-height: 1.6;
    margin-bottom: 1rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-card-link {
    font-size: 12px;
    font-weight: 600;
    color: #06b6d4;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: gap 0.2s;
}

.blog-card-link:hover {
    gap: 0.75rem;
}

.blog-view-all {
    text-align: center;
    margin-top: 3rem;
}

.btn-view-all {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 2rem;
    background: transparent;
    border: 1px solid #0f172a;
    color: #0f172a;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    text-decoration: none;
    transition: all 0.3s;
}

.btn-view-all:hover {
    background: #0f172a;
    color: #fff;
}

/* === FAQ SECTION (Technical Support Protocol) === */
.faq-section-new {
    padding: 6rem 0;
    background: #fff;
    border-top: 1px solid #e2e8f0;
    position: relative;
    z-index: 10;
}

.faq-container {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.faq-header {
    text-align: center;
    margin-bottom: 4rem;
}

.faq-title {
    font-size: 1.875rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 1rem;
}

.faq-subtitle {
    font-size: 0.875rem;
    color: #64748b;
}

.faq-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.faq-item {
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    transition: background 0.3s;
}

.faq-item[open] {
    background: #fff;
}

.faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem;
    font-weight: 500;
    cursor: pointer;
    list-style: none;
    color: #0f172a;
    transition: color 0.2s;
}

.faq-question:hover {
    color: #3b82f6;
}

.faq-question::-webkit-details-marker {
    display: none;
}

.faq-chevron {
    color: #cbd5e1;
    transition: transform 0.3s, color 0.2s;
}

.faq-question:hover .faq-chevron {
    color: #3b82f6;
}

.faq-item[open] .faq-chevron {
    transform: rotate(180deg);
}

.faq-answer {
    padding: 0 1.5rem 1.5rem;
    font-size: 0.875rem;
    color: #64748b;
    line-height: 1.7;
    border-top: 1px solid transparent;
}

.faq-item[open] .faq-answer {
    border-top-color: #f1f5f9;
}

/* === BLOG SECTION DARK (Intelligence Feed) === */
.blog-section-dark {
    padding: 8rem 0;
    background: #02040a;
    border-top: 1px solid rgba(255,255,255,0.05);
    position: relative;
    z-index: 20;
}

.blog-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.blog-header {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    margin-bottom: 4rem;
}

@media (min-width: 768px) {
    .blog-header {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-end;
    }
}

.blog-header-left {
    flex: 1;
}

.blog-label {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #06b6d4;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.blog-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
    .blog-title {
        font-size: 3rem;
    }
}

.blog-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.category-pill {
    padding: 0.5rem 1rem;
    border-radius: 2px;
    border: 1px solid rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.05);
    color: #94a3b8;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    transition: all 0.2s;
}

.category-pill:hover {
    border-color: rgba(255,255,255,0.3);
    color: #fff;
}

.category-pill.active {
    border-color: rgba(6, 182, 212, 0.3);
    background: rgba(6, 182, 212, 0.1);
    color: #06b6d4;
}

.blog-view-all-link {
    font-size: 12px;
    font-family: 'JetBrains Mono', monospace;
    color: #94a3b8;
    text-decoration: none;
    border-bottom: 1px solid #334155;
    padding-bottom: 0.25rem;
    transition: all 0.2s;
}

.blog-view-all-link:hover {
    color: #fff;
    border-color: #fff;
}

.blog-grid-dark {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 1024px) {
    .blog-grid-dark {
        grid-template-columns: 7fr 5fr;
    }
}

/* Featured Post */
.blog-featured {
    position: relative;
    display: block;
    text-decoration: none;
    border-radius: 8px;
    overflow: hidden;
    min-height: 450px;
}

.blog-featured-glow {
    position: absolute;
    inset: -2px;
    background: linear-gradient(to right, #06b6d4, #3b82f6);
    border-radius: 10px;
    opacity: 0.2;
    transition: opacity 0.5s;
    filter: blur(4px);
}

.blog-featured:hover .blog-featured-glow {
    opacity: 0.7;
}

.blog-featured-inner {
    position: relative;
    height: 100%;
    min-height: 450px;
    background: rgba(15, 23, 42, 0.6);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 2rem;
}

.blog-featured-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.blog-featured-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.5;
    filter: grayscale(100%);
    transition: all 0.7s;
}

.blog-featured:hover .blog-featured-bg img {
    filter: grayscale(0%);
    transform: scale(1.05);
}

.blog-featured-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, #0f172a 0%, rgba(15, 23, 42, 0.6) 50%, transparent 100%);
    z-index: 1;
}

.blog-featured-content {
    position: relative;
    z-index: 10;
}

.blog-featured-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.blog-featured-badge {
    background: rgba(244, 63, 94, 0.2);
    color: #f43f5e;
    border: 1px solid rgba(244, 63, 94, 0.3);
    font-size: 9px;
    font-weight: 700;
    padding: 0.25rem 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border-radius: 2px;
}

.blog-featured-date {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #94a3b8;
}

.blog-featured-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 1rem;
    line-height: 1.3;
    transition: color 0.3s;
}

@media (min-width: 768px) {
    .blog-featured-title {
        font-size: 1.875rem;
    }
}

.blog-featured:hover .blog-featured-title {
    color: #06b6d4;
}

.blog-featured-excerpt {
    font-size: 0.875rem;
    color: #cbd5e1;
    line-height: 1.7;
    margin-bottom: 2rem;
    max-width: 500px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-featured-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: transform 0.2s;
}

.blog-featured-link i {
    color: #06b6d4;
}

.blog-featured:hover .blog-featured-link {
    transform: translateX(8px);
}

/* Side List */
.blog-side-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.blog-side-item {
    display: flex;
    gap: 1rem;
    padding: 1.5rem;
    background: rgba(15, 23, 42, 0.6);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.08);
    border-left: 2px solid transparent;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.3s;
    position: relative;
    overflow: hidden;
}

.blog-side-item:hover {
    border-left-color: #06b6d4;
}

.blog-side-item[data-color="neon-safe"]:hover {
    border-left-color: #10b981;
}

.blog-side-item[data-color="neon-blue"]:hover {
    border-left-color: #3b82f6;
}

.blog-side-item[data-color="neon-warn"]:hover {
    border-left-color: #f59e0b;
}

.blog-side-icon {
    position: absolute;
    right: 1rem;
    top: 1rem;
    font-size: 1.25rem;
    color: #334155;
    transition: color 0.3s;
}

.blog-side-item:hover .blog-side-icon {
    color: #06b6d4;
}

.blog-side-item[data-color="neon-safe"]:hover .blog-side-icon {
    color: #10b981;
}

.blog-side-item[data-color="neon-blue"]:hover .blog-side-icon {
    color: #3b82f6;
}

.blog-side-item[data-color="neon-warn"]:hover .blog-side-icon {
    color: #f59e0b;
}

.blog-side-content {
    flex: 1;
    padding-right: 2rem;
}

.blog-side-meta {
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.blog-side-badge {
    font-size: 9px;
    font-family: 'JetBrains Mono', monospace;
    font-weight: 700;
    text-transform: uppercase;
    padding: 0.15rem 0.4rem;
    border-radius: 2px;
    background: rgba(6, 182, 212, 0.1);
    color: #06b6d4;
    border: 1px solid rgba(6, 182, 212, 0.3);
}

.blog-side-badge[data-color="neon-safe"] {
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
    border-color: rgba(16, 185, 129, 0.3);
}

.blog-side-badge[data-color="neon-blue"] {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
    border-color: rgba(59, 130, 246, 0.3);
}

.blog-side-badge[data-color="neon-warn"] {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
    border-color: rgba(245, 158, 11, 0.3);
}

.blog-side-date {
    font-size: 9px;
    font-family: 'JetBrains Mono', monospace;
    color: #64748b;
}

.blog-side-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.5rem;
    line-height: 1.4;
    transition: color 0.3s;
}

.blog-side-item:hover .blog-side-title {
    color: #06b6d4;
}

.blog-side-item[data-color="neon-safe"]:hover .blog-side-title {
    color: #10b981;
}

.blog-side-item[data-color="neon-blue"]:hover .blog-side-title {
    color: #3b82f6;
}

.blog-side-item[data-color="neon-warn"]:hover .blog-side-title {
    color: #f59e0b;
}

.blog-side-excerpt {
    font-size: 12px;
    color: #94a3b8;
    line-height: 1.5;
}

/* ============================================
   BLOG SINGLE POST - CINEMATIC STYLE
   ============================================ */

/* Reading Progress Bar */
.reading-progress {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    background: #06b6d4;
    z-index: 100;
    width: 0%;
    transition: width 0.1s;
}

/* Article Hero */
.article-hero {
    position: relative;
    min-height: 500px;
    padding-top: 80px; /* Space for fixed navbar */
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    background: #050b14;
}

@media (min-width: 768px) {
    .article-hero {
        min-height: 70vh;
    }
}

.article-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.article-hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.5) contrast(1.1) grayscale(100%);
    transition: transform 2s ease-out;
}

.article-hero:hover .article-hero-bg img {
    transform: scale(1.05);
}

.article-hero-grid {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(255,255,255,0.1) 1px, transparent 1px),
                linear-gradient(to bottom, rgba(255,255,255,0.1) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.3;
    mix-blend-mode: overlay;
}

.article-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, #020408 0%, rgba(2,4,8,0.6) 50%, transparent 100%);
    z-index: 1;
}

.article-hero-content {
    position: relative;
    z-index: 10;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem 4rem;
}

.article-hero-inner {
    max-width: 900px;
}

.article-meta-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.article-breadcrumb {
    padding: 0.375rem 0.75rem;
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 2px;
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    font-weight: 700;
    text-transform: uppercase;
    color: #fff;
    text-decoration: none;
    transition: background 0.2s;
}

.article-breadcrumb:hover {
    background: rgba(255,255,255,0.2);
}

.article-meta-dot {
    color: #06b6d4;
    font-size: 1.25rem;
}

.article-category {
    font-size: 11px;
    font-family: 'JetBrains Mono', monospace;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: #06b6d4;
    text-decoration: none;
}

.article-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.1;
    letter-spacing: -0.03em;
    margin-bottom: 2rem;
}

@media (min-width: 768px) {
    .article-title {
        font-size: 3.5rem;
    }
}

@media (min-width: 1024px) {
    .article-title {
        font-size: 4rem;
    }
}

.article-meta-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,0.2);
}

.article-author {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding-right: 1.5rem;
    border-right: 1px solid rgba(255,255,255,0.2);
}

.article-author-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, #06b6d4, #3b82f6);
    padding: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.article-author-avatar span {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: #050b14;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
}

.article-author-info {
    display: flex;
    flex-direction: column;
}

.article-author-name {
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    line-height: 1.2;
}

.article-author-title {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #06b6d4;
    text-transform: uppercase;
}

.article-meta-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 12px;
    font-family: 'JetBrains Mono', monospace;
    color: #cbd5e1;
}

.article-meta-item i {
    color: #06b6d4;
}

.article-share {
    display: flex;
    gap: 0.5rem;
    margin-left: auto;
}

.article-share-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    border: none;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
}

.article-share-btn:hover {
    background: #06b6d4;
    color: #000;
}

/* Article Container */
.article-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 3rem 1.5rem;
}

.article-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
}

@media (min-width: 1024px) {
    .article-grid {
        grid-template-columns: 1fr 320px;
    }
}

/* Article Main */
.article-main {
    min-width: 0;
}

/* AI Summary */
.article-summary {
    background: #f0f9ff;
    border-left: 3px solid #06b6d4;
    padding: 1.5rem;
    margin-bottom: 2.5rem;
    border-radius: 0 4px 4px 0;
}

.article-summary-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: #06b6d4;
}

.pulse-dot {
    width: 8px;
    height: 8px;
    background: #06b6d4;
    border-radius: 50%;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

.article-summary p {
    font-size: 14px;
    color: #475569;
    line-height: 1.7;
    margin: 0;
}

/* Article Prose - Enhanced Typography */
.article-prose {
    color: #334155;
    font-size: 1.1rem;
    line-height: 1.9;
    max-width: 720px;
}

.article-prose h2 {
    font-size: 1.875rem;
    font-weight: 700;
    color: #0f172a;
    margin-top: 3rem;
    margin-bottom: 1.25rem;
    letter-spacing: -0.03em;
    scroll-margin-top: 100px;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid #06b6d4;
}

.article-prose h3 {
    font-size: 1.5rem;
    font-weight: 600;
    color: #1e293b;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    scroll-margin-top: 100px;
}

.article-prose h4 {
    font-size: 1.25rem;
    font-weight: 600;
    color: #334155;
    margin-top: 2rem;
    margin-bottom: 0.75rem;
    scroll-margin-top: 100px;
}

.article-prose p {
    margin-bottom: 1.5rem;
}

/* Fix for content with only <br> tags - add spacing */
.article-prose br + br {
    display: block;
    content: '';
    margin-top: 1rem;
}

.article-prose ul,
.article-prose ol {
    margin-bottom: 1.5rem;
    padding-left: 0;
    list-style: none;
}

.article-prose ul li,
.article-prose ol li {
    position: relative;
    padding-left: 1.75rem;
    margin-bottom: 0.75rem;
}

.article-prose ul li::before {
    content: "→";
    color: #06b6d4;
    position: absolute;
    left: 0;
    font-weight: bold;
}

.article-prose ol {
    counter-reset: list-counter;
}

.article-prose ol li {
    counter-increment: list-counter;
}

.article-prose ol li::before {
    content: counter(list-counter) ".";
    color: #06b6d4;
    position: absolute;
    left: 0;
    font-weight: 700;
}

.article-prose strong {
    color: #0f172a;
    font-weight: 600;
}

.article-prose em {
    font-style: italic;
    color: #475569;
}

.article-prose blockquote {
    border-left: 4px solid #06b6d4;
    padding: 1.5rem 1.5rem 1.5rem 2rem;
    font-style: italic;
    color: #475569;
    background: linear-gradient(135deg, #f0f9ff 0%, #f8fafc 100%);
    border-radius: 0 8px 8px 0;
    margin: 2rem 0;
    position: relative;
}

.article-prose blockquote::before {
    content: '"';
    position: absolute;
    top: -10px;
    left: 10px;
    font-size: 4rem;
    color: #06b6d4;
    opacity: 0.3;
    font-family: Georgia, serif;
    line-height: 1;
}

.article-prose a {
    color: #06b6d4;
    text-decoration: underline;
    text-decoration-color: rgba(6, 182, 212, 0.3);
    text-underline-offset: 2px;
    transition: all 0.2s;
}

.article-prose a:hover {
    color: #0891b2;
    text-decoration-color: #0891b2;
}

.article-prose img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin: 2rem 0;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.article-prose figure {
    margin: 2rem 0;
}

.article-prose figcaption {
    text-align: center;
    font-size: 0.875rem;
    color: #64748b;
    margin-top: 0.75rem;
    font-style: italic;
}

.article-prose pre,
.article-prose code {
    font-family: 'JetBrains Mono', monospace;
}

.article-prose pre {
    background: #0f172a;
    color: #e2e8f0;
    padding: 1.5rem;
    border-radius: 8px;
    overflow-x: auto;
    margin: 2rem 0;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.article-prose code {
    background: #f1f5f9;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    font-size: 0.9em;
    color: #0f172a;
}

.article-prose pre code {
    background: transparent;
    padding: 0;
    color: inherit;
}

/* Tables in article */
.article-prose table {
    width: 100%;
    margin: 2rem 0;
    border-collapse: collapse;
    font-size: 0.95rem;
}

.article-prose th,
.article-prose td {
    padding: 0.75rem 1rem;
    text-align: left;
    border-bottom: 1px solid #e2e8f0;
}

.article-prose th {
    background: #f8fafc;
    font-weight: 600;
    color: #0f172a;
    border-bottom: 2px solid #06b6d4;
}

.article-prose tr:hover td {
    background: #f8fafc;
}

/* Horizontal rule */
.article-prose hr {
    border: none;
    height: 2px;
    background: linear-gradient(90deg, transparent, #06b6d4, transparent);
    margin: 3rem 0;
}

/* Lead paragraph (first paragraph) */
.article-prose > p:first-of-type {
    font-size: 1.25rem;
    line-height: 1.8;
    color: #475569;
    font-weight: 300;
}

/* Article FAQ */
.article-faq {
    margin-top: 4rem;
    padding-top: 2.5rem;
    border-top: 1px solid #e2e8f0;
}

.article-faq-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 1.5rem;
}

.article-faq-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.article-faq-item {
    border: 1px solid #e2e8f0;
    background: #fff;
    border-radius: 2px;
    transition: all 0.2s;
}

.article-faq-item[open] {
    box-shadow: 0 0 0 1px rgba(6, 182, 212, 0.5);
}

.article-faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    font-weight: 500;
    color: #1e293b;
    cursor: pointer;
    list-style: none;
    transition: color 0.2s;
}

.article-faq-question:hover {
    color: #3b82f6;
}

.article-faq-question::-webkit-details-marker {
    display: none;
}

.article-faq-question i {
    color: #cbd5e1;
    transition: transform 0.2s;
}

.article-faq-item[open] .article-faq-question i {
    transform: rotate(45deg);
}

.article-faq-answer {
    padding: 0 1rem 1rem;
    font-size: 14px;
    color: #475569;
    line-height: 1.7;
}

/* Article CTA */
.article-cta {
    margin-top: 4rem;
    background: #0f172a;
    padding: 3rem;
    border-radius: 4px;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.article-cta::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, rgba(6, 182, 212, 0.15) 0%, transparent 70%);
    pointer-events: none;
}

.article-cta-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 1rem;
    position: relative;
    z-index: 1;
}

.article-cta-text {
    font-size: 14px;
    color: #94a3b8;
    margin-bottom: 2rem;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    z-index: 1;
}

.article-cta-btn {
    display: inline-block;
    padding: 1rem 2rem;
    background: #06b6d4;
    color: #000;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    border-radius: 2px;
    box-shadow: 0 0 30px rgba(6, 182, 212, 0.4);
    transition: all 0.2s;
    position: relative;
    z-index: 1;
}

.article-cta-btn:hover {
    background: #22d3ee;
    transform: translateY(-2px);
}

.article-cta-note {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-top: 1rem;
    position: relative;
    z-index: 1;
}

/* Sidebar */
.article-sidebar {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.sidebar-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    padding: 1.5rem;
    border-radius: 2px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.sidebar-author {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.sidebar-author-avatar {
    width: 48px;
    height: 48px;
    background: #1e293b;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
}

.sidebar-author-name {
    font-weight: 700;
    color: #0f172a;
    font-size: 14px;
}

.sidebar-author-title {
    font-size: 11px;
    font-family: 'JetBrains Mono', monospace;
    color: #64748b;
}

.sidebar-author-bio {
    font-size: 12px;
    color: #475569;
    line-height: 1.6;
    margin: 0;
}

.sidebar-toc-wrapper {
    position: sticky;
    top: 80px;
}

.sidebar-label {
    display: block;
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 1rem;
}

.sidebar-toc {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.sidebar-toc .toc-link {
    display: block;
    padding: 0.375rem 0.75rem;
    font-size: 13px;
    color: #475569;
    text-decoration: none;
    border-left: 2px solid transparent;
    transition: all 0.2s;
}

.sidebar-toc .toc-link:hover {
    color: #0f172a;
}

.sidebar-toc .toc-link.active {
    color: #06b6d4;
    border-left-color: #06b6d4;
    font-weight: 600;
}

.sidebar-toc .toc-link.toc-sub {
    padding-left: 1.5rem;
    font-size: 12px;
}

/* Related Posts */
.article-related {
    margin-top: 4rem;
    padding-top: 3rem;
    border-top: 1px solid #e2e8f0;
}

.article-related-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 1.5rem;
}

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

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

.related-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    overflow: hidden;
    text-decoration: none;
    transition: all 0.3s;
}

.related-card:hover {
    border-color: #06b6d4;
    transform: translateY(-4px);
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

.related-card-image {
    aspect-ratio: 16/9;
    overflow: hidden;
}

.related-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s;
}

.related-card:hover .related-card-image img {
    transform: scale(1.05);
}

.related-card-content {
    padding: 1.25rem;
}

.related-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 0.5rem;
    line-height: 1.4;
    transition: color 0.2s;
}

.related-card:hover .related-card-title {
    color: #06b6d4;
}

.related-card-excerpt {
    font-size: 13px;
    color: #64748b;
    line-height: 1.5;
    margin: 0;
}

/* ============================================
   BLOG SINGLE POST - CINEMATIC STYLE (React-like)
   ============================================ */

/* Reading Progress Bar */
.blog-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    background: #06b6d4;
    z-index: 100;
    width: 0%;
    transition: width 0.1s;
}

/* Simple Dark Navbar */
.blog-nav-simple {
    width: 100%;
    background: #020408;
    color: #fff;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    position: sticky;
    top: 0;
    z-index: 50;
}

.blog-nav-inner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.blog-nav-brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none !important;
}

.blog-nav-logo {
    width: 32px;
    height: 32px;
    background: #06b6d4;
    color: #000;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
    border-radius: 2px;
}

.blog-nav-text {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.02em;
}

.blog-nav-text .accent {
    color: #06b6d4;
}

.blog-nav-cta {
    font-size: 12px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.1);
    color: #fff;
    padding: 0.5rem 1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none !important;
    transition: all 0.2s;
}

.blog-nav-cta:hover {
    background: rgba(255,255,255,0.2);
    color: #fff;
}

/* Article Hero */
.blog-hero {
    position: relative;
    min-height: 500px;
    height: 60vh;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    background: #050b14;
}

.blog-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    transition: transform 2s ease-out;
}

.blog-hero:hover .blog-hero-bg {
    transform: scale(1.05);
}

.blog-hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    filter: brightness(0.5) contrast(1.1) grayscale(1);
}

.blog-hero-grid {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(255,255,255,0.05) 1px, transparent 1px),
                linear-gradient(to bottom, rgba(255,255,255,0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    mix-blend-mode: overlay;
    opacity: 0.3;
    z-index: 10;
}

.blog-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, #020408, rgba(2,4,8,0.6) 50%, transparent);
    z-index: 10;
}

.blog-hero-content {
    position: relative;
    z-index: 20;
    max-width: 1440px;
    width: 100%;
    margin: 0 auto;
    padding: 0 1.5rem 4rem;
}

.blog-hero-inner {
    max-width: 900px;
}

/* Meta Top (Breadcrumbs) */
.blog-hero-meta-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    animation: blogFadeUp 0.8s ease-out forwards;
}

.blog-breadcrumb {
    padding: 0.25rem 0.75rem;
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 4px;
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    font-weight: 700;
    text-transform: uppercase;
    color: #fff;
    text-decoration: none !important;
    transition: background 0.2s;
}

.blog-breadcrumb:hover {
    background: rgba(255,255,255,0.2);
    color: #fff;
}

.blog-meta-dot {
    color: #06b6d4;
    font-size: 18px;
}

.blog-category-label {
    color: #06b6d4;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
}

/* Hero Title */
.blog-hero-title {
    font-size: clamp(2rem, 6vw, 4rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.1;
    letter-spacing: -0.03em;
    margin-bottom: 2rem;
    animation: blogFadeUp 0.8s ease-out 0.1s forwards;
    opacity: 0;
}

/* Meta Bar */
.blog-hero-meta-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.5rem;
    border-top: 1px solid rgba(255,255,255,0.2);
    padding-top: 1.5rem;
    animation: blogFadeUp 0.8s ease-out 0.2s forwards;
    opacity: 0;
}

.blog-meta-author {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding-right: 1.5rem;
    border-right: 1px solid rgba(255,255,255,0.2);
}

.blog-meta-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, #06b6d4, #3b82f6);
    padding: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.blog-meta-avatar span {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: #050b14;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 12px;
}

.blog-meta-author-info {
    display: flex;
    flex-direction: column;
}

.blog-meta-author-name {
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.2;
}

.blog-meta-author-title {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #06b6d4;
    text-transform: uppercase;
}

.blog-meta-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    color: #cbd5e1;
}

.blog-meta-item i {
    color: #06b6d4;
}

.blog-meta-share {
    margin-left: auto;
    display: flex;
    gap: 0.75rem;
}

.blog-meta-share button {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    border: none;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.blog-meta-share button:hover {
    background: #06b6d4;
    color: #000;
}

/* Content Wrapper */
.blog-content-wrapper {
    max-width: 1440px;
    margin: 0 auto;
    padding: 3rem 1.5rem;
    background-color: #f8fafc !important;
}

.blog-content-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    background: transparent;
}

/* Ensure no white background on blog content area */
.blog-content-wrapper,
.blog-content-grid,
.blog-main,
.blog-prose {
    background-color: transparent !important;
}

@media (min-width: 1024px) {
    .blog-content-grid {
        grid-template-columns: 2fr 1fr;
    }
}

/* Main Content */
.blog-main {
    min-width: 0;
    background: transparent;
}

/* AI Summary */
.blog-ai-summary {
    background: #f0f9ff;
    border-left: 3px solid #06b6d4;
    padding: 1.5rem;
    margin-bottom: 2.5rem;
    border-radius: 0 4px 4px 0;
}

.blog-ai-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.blog-ai-dot {
    width: 8px;
    height: 8px;
    background: #06b6d4;
    border-radius: 50%;
    animation: blogPulse 2s infinite;
}

.blog-ai-label span {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: #06b6d4;
}

.blog-ai-summary p {
    font-size: 14px;
    color: #475569;
    line-height: 1.7;
    margin: 0;
}

.blog-ai-summary strong {
    color: #0f172a;
}

/* Article Prose */
.blog-prose {
    color: #1e293b;
    background: transparent;
}

.blog-prose h2 {
    font-size: 1.8rem;
    font-weight: 700;
    color: #0f172a;
    margin-top: 3rem;
    margin-bottom: 1rem;
    letter-spacing: -0.03em;
    scroll-margin-top: 100px;
}

.blog-prose h3 {
    font-size: 1.4rem;
    font-weight: 600;
    color: #1e293b;
    margin-top: 2rem;
    margin-bottom: 0.8rem;
    scroll-margin-top: 100px;
}

.blog-prose h4 {
    font-size: 1.2rem;
    font-weight: 600;
    color: #334155;
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
    scroll-margin-top: 100px;
}

.blog-prose p {
    margin-bottom: 1.5rem;
    line-height: 1.8;
    color: #334155;
    font-size: 1.05rem;
}

.blog-prose p.lead {
    font-size: 1.25rem;
    color: #475569;
    font-weight: 300;
}

.blog-prose ul,
.blog-prose ol {
    list-style: none;
    padding-left: 0;
    margin-bottom: 1.5rem;
}

.blog-prose li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.75rem;
    color: #334155;
    line-height: 1.7;
}

.blog-prose li::before {
    content: "→";
    color: #06b6d4;
    position: absolute;
    left: 0;
    font-weight: bold;
}

.blog-prose ol {
    counter-reset: list-counter;
}

.blog-prose ol li::before {
    counter-increment: list-counter;
    content: counter(list-counter) ".";
    color: #06b6d4;
    font-weight: 700;
}

.blog-prose strong {
    color: #0f172a;
    font-weight: 600;
}

.blog-prose blockquote {
    border-left: 4px solid #06b6d4;
    padding: 1.5rem;
    font-style: italic;
    color: #475569;
    background: #f1f5f9;
    border-radius: 0 4px 4px 0;
    margin: 1.5rem 0;
}

.blog-prose blockquote p {
    margin: 0;
}

.blog-prose a {
    color: #06b6d4;
    text-decoration: none !important;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s;
}

.blog-prose a:hover {
    border-bottom-color: #06b6d4;
    color: #0891b2;
}

.blog-prose img {
    max-width: 100%;
    height: auto;
    border-radius: 4px;
    margin: 2rem 0;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1);
}

.blog-prose table {
    width: 100%;
    border-collapse: collapse;
    margin: 2rem 0;
    font-size: 14px;
}

.blog-prose th,
.blog-prose td {
    padding: 0.75rem 1rem;
    border: 1px solid #e2e8f0;
    text-align: left;
}

.blog-prose th {
    background: #f1f5f9;
    font-weight: 600;
    color: #0f172a;
}

.blog-prose tr:nth-child(even) td {
    background: #f8fafc;
}

.blog-prose pre,
.blog-prose code {
    font-family: 'JetBrains Mono', monospace;
}

.blog-prose pre {
    background: #0f172a;
    color: #e2e8f0;
    padding: 1.5rem;
    border-radius: 4px;
    overflow-x: auto;
    margin: 1.5rem 0;
    font-size: 14px;
}

.blog-prose code {
    background: #f1f5f9;
    padding: 0.2rem 0.4rem;
    border-radius: 3px;
    font-size: 0.9em;
    color: #0f172a;
}

.blog-prose pre code {
    background: transparent;
    padding: 0;
    color: inherit;
}

.blog-prose hr {
    border: none;
    height: 1px;
    background: linear-gradient(to right, transparent, #cbd5e1, transparent);
    margin: 3rem 0;
}

/* FAQ Section */
.blog-faq {
    margin-top: 4rem;
    padding-top: 2.5rem;
    border-top: 1px solid #e2e8f0;
}

.blog-faq h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 1.5rem;
}

.blog-faq-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.blog-faq-item {
    border: 1px solid #e2e8f0;
    background: #fff;
    border-radius: 2px;
    transition: all 0.2s;
}

.blog-faq-item[open] {
    box-shadow: 0 0 0 1px rgba(6,182,212,0.5);
}

.blog-faq-item summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    cursor: pointer;
    font-weight: 500;
    color: #1e293b;
    list-style: none;
    transition: color 0.2s;
}

.blog-faq-item summary::-webkit-details-marker {
    display: none;
}

.blog-faq-item summary:hover {
    color: #3b82f6;
}

.blog-faq-item summary i {
    color: #94a3b8;
    transition: transform 0.2s;
}

.blog-faq-item[open] summary i {
    transform: rotate(45deg);
}

.blog-faq-answer {
    padding: 0 1rem 1rem;
    font-size: 14px;
    color: #475569;
    line-height: 1.7;
    border-top: 1px solid rgba(226,232,240,0.5);
    margin-top: 0.5rem;
    padding-top: 0.75rem;
}

/* Final CTA */
.blog-final-cta {
    margin-top: 4rem;
    background: #0f172a;
    color: #fff;
    padding: 3rem 2rem;
    border-radius: 4px;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.blog-cta-glow {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, rgba(6,182,212,0.15) 0%, transparent 70%);
    opacity: 0.2;
}

.blog-final-cta h3 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
    position: relative;
    z-index: 10;
    color: #fff;
}

.blog-final-cta p {
    color: #94a3b8;
    margin-bottom: 2rem;
    position: relative;
    z-index: 10;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}

.blog-cta-btn {
    display: inline-block;
    padding: 1rem 2rem;
    background: #06b6d4;
    color: #000;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none !important;
    border-radius: 2px;
    box-shadow: 0 10px 30px rgba(6,182,212,0.3);
    transition: all 0.2s;
    position: relative;
    z-index: 10;
}

.blog-cta-btn:hover {
    background: #22d3ee;
    transform: translateY(-2px);
    color: #000;
}

.blog-cta-note {
    display: block;
    margin-top: 1rem;
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    position: relative;
    z-index: 10;
}

/* Sidebar */
.blog-sidebar {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.blog-sidebar-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    padding: 1.5rem;
    border-radius: 2px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.blog-sidebar-author {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.blog-sidebar-avatar {
    width: 48px;
    height: 48px;
    background: #1e293b;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    border-radius: 50%;
    font-size: 14px;
}

.blog-sidebar-name {
    font-weight: 700;
    color: #0f172a;
    font-size: 14px;
}

.blog-sidebar-title {
    font-size: 11px;
    font-family: 'JetBrains Mono', monospace;
    color: #64748b;
}

.blog-sidebar-bio {
    font-size: 12px;
    color: #475569;
    line-height: 1.6;
    margin-bottom: 1rem;
}

.blog-sidebar-social {
    display: flex;
    gap: 0.75rem;
}

.blog-sidebar-social a {
    color: #94a3b8;
    text-decoration: none !important;
    transition: color 0.2s;
}

.blog-sidebar-social a:hover {
    color: #3b82f6;
}

/* Sticky Sidebar */
.blog-sidebar-sticky {
    position: sticky;
    top: 80px;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.blog-sidebar-label {
    display: block;
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 1rem;
}

/* TOC */
.blog-toc {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.blog-toc-link {
    display: block;
    padding: 0.375rem 0.75rem;
    font-size: 13px;
    color: #475569;
    text-decoration: none !important;
    border-left: 2px solid transparent;
    transition: all 0.2s;
}

.blog-toc-link:hover {
    color: #0f172a;
}

.blog-toc-link.active {
    color: #06b6d4;
    border-left-color: #06b6d4;
    font-weight: 600;
}

.blog-toc-link.blog-toc-sub {
    padding-left: 1.5rem;
    font-size: 12px;
}

/* Mini Promo */
.blog-sidebar-promo {
    padding: 1.5rem;
    background: linear-gradient(135deg, #0f172a, #1e293b);
    border-radius: 2px;
    color: #fff;
}

.blog-sidebar-promo i {
    font-size: 1.5rem;
    color: #06b6d4;
    margin-bottom: 0.75rem;
    display: block;
}

.blog-sidebar-promo h4 {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: #fff;
}

.blog-sidebar-promo p {
    font-size: 12px;
    color: #94a3b8;
    margin-bottom: 1rem;
    line-height: 1.5;
}

.blog-sidebar-promo a {
    font-size: 12px;
    font-weight: 700;
    color: #06b6d4;
    text-decoration: none !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid rgba(6,182,212,0.3);
    padding-bottom: 2px;
    transition: border-color 0.2s;
}

.blog-sidebar-promo a:hover {
    border-bottom-color: #06b6d4;
    color: #fff;
}

/* Simple Footer */
.blog-footer-simple {
    background: #020408;
    border-top: 1px solid rgba(255,255,255,0.1);
    padding: 2rem 0;
    text-align: center;
    color: #64748b;
    font-size: 12px;
    font-family: 'JetBrains Mono', monospace;
}

/* Animations */
@keyframes blogFadeUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes blogPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* Responsive */
@media (max-width: 768px) {
    .blog-hero {
        min-height: 400px;
        height: auto;
    }
    
    .blog-hero-title {
        font-size: 1.75rem;
    }
    
    .blog-meta-author {
        padding-right: 0;
        border-right: none;
        width: 100%;
    }
    
    .blog-meta-share {
        margin-left: 0;
        width: 100%;
        justify-content: flex-start;
    }
    
    .blog-hero-meta-bar {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ============================================
   REGISTRATION PAGE - CINEMATIC STYLE
   ============================================ */

.register-cinematic {
    min-height: 100vh;
    background-color: #020408;
    color: #e2e8f0;
}

.register-layout {
    display: flex;
    min-height: calc(100vh - 80px); /* Account for navbar */
}

/* Left Column - Form */
.register-form-column {
    width: 100%;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background: #020408;
    position: relative;
    z-index: 10;
}

@media (min-width: 1024px) {
    .register-form-column {
        width: 50%;
        padding: 3rem;
    }
}

@media (min-width: 1280px) {
    .register-form-column {
        width: 41.666%;
        padding: 3rem 4rem;
    }
}

.register-form-wrapper {
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* Step Header */
.register-step-header {
    margin-bottom: 2rem;
}

.register-step-label {
    display: block;
    color: #06b6d4;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 0.5rem;
}

.register-title {
    font-size: 1.875rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.5rem;
    letter-spacing: -0.02em;
}

.register-subtitle {
    color: #94a3b8;
    font-size: 14px;
    margin: 0;
}

.register-back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: #64748b;
    font-size: 12px;
    text-decoration: none !important;
    margin-bottom: 1rem;
    transition: color 0.2s;
}

.register-back-link:hover {
    color: #fff;
}

/* Alerts */
.register-alert {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    border-radius: 2px;
    margin-bottom: 1.5rem;
    font-size: 14px;
}

.register-alert-success {
    background: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.3);
    color: #10b981;
}

.register-alert-error {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #ef4444;
}

/* Form */
.register-form {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.register-field {
    display: flex;
    flex-direction: column;
}

.register-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.register-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 0.5rem;
}

.register-label-hint {
    font-size: 10px;
    color: #475569;
    cursor: help;
}

/* .register-input extends .cinematic-input */
.register-input {
    background-color: #0b1221;
    border: 1px solid #1e293b;
    color: #fff;
    padding: 0.75rem 1rem;
    font-size: 14px;
    border-radius: 2px;
    transition: all 0.3s ease;
    width: 100%;
}

.register-input:focus {
    border-color: #06b6d4;
    box-shadow: 0 0 0 1px rgba(6, 182, 212, 0.3);
    outline: none;
    background-color: #0f172a;
}

.register-input::placeholder {
    color: #475569;
}

.register-input-icon {
    position: relative;
}

.register-input-icon i {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: #64748b;
    font-size: 14px;
}

.register-input-with-icon {
    padding-left: 2.5rem;
}

.register-field-error {
    color: #ef4444;
    font-size: 12px;
    margin-top: 0.25rem;
}

.register-field-note {
    color: #475569;
    font-size: 11px;
    margin-top: 0.25rem;
}

/* Password Meter */
.register-password-meter {
    display: flex;
    gap: 0.25rem;
    margin-top: 0.5rem;
    height: 4px;
}

.register-password-bar {
    flex: 1;
    background: #1e293b;
    border-radius: 2px;
    overflow: hidden;
    transition: all 0.3s;
}

.register-password-bar > div {
    height: 100%;
    width: 0;
    transition: width 0.3s, background-color 0.3s;
}

/* Consents */
.register-consents {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.register-consent-item {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
}

.register-consent-item input[type="checkbox"] {
    margin-top: 2px;
    accent-color: #06b6d4;
}

.register-consent-item label {
    font-size: 12px;
    color: #64748b;
    line-height: 1.5;
}

.register-consent-item a {
    color: #94a3b8;
    text-decoration: underline;
    text-decoration-color: #475569;
}

.register-consent-item a:hover {
    color: #fff;
}

.register-admin-note {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 12px;
    color: #64748b;
    margin: 0.5rem 0;
}

.register-admin-note i {
    color: #06b6d4;
}

/* Primary Button */
.register-btn-primary {
    width: 100%;
    padding: 0.875rem 1.5rem;
    background: #06b6d4;
    color: #000;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: none;
    border-radius: 2px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    box-shadow: 0 0 20px rgba(6, 182, 212, 0.2);
    transition: all 0.2s;
}

.register-btn-primary:hover {
    background: #22d3ee;
    transform: translateY(-1px);
}

/* Footer Link */
.register-footer-link {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    text-align: center;
}

.register-footer-link p {
    font-size: 12px;
    color: #64748b;
    margin: 0;
}

.register-footer-link a {
    color: #06b6d4;
    text-decoration: none !important;
    transition: color 0.2s;
}

.register-footer-link a:hover {
    color: #fff;
}

/* Form Footer */
.register-form-footer {
    display: flex;
    justify-content: space-between;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #475569;
    margin-top: 2rem;
}

.register-form-footer span {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Right Column - Visual */
.register-visual-column {
    display: none;
    position: relative;
    overflow: hidden;
    background: #050b14;
}

@media (min-width: 1024px) {
    .register-visual-column {
        display: block;
        width: 50%;
    }
}

@media (min-width: 1280px) {
    .register-visual-column {
        width: 58.333%;
    }
}

.register-visual-bg {
    position: absolute;
    inset: 0;
}

.register-visual-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.4;
    filter: grayscale(1) contrast(1.25);
}

.register-visual-grid {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
                linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.2;
    mix-blend-mode: overlay;
}

.register-visual-gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #020408, transparent, transparent);
}

.register-visual-content {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 4rem;
    z-index: 20;
}

/* Testimonial */
.register-testimonial {
    background: rgba(15, 23, 42, 0.8);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 2rem;
    border-radius: 2px;
    max-width: 500px;
    transition: transform 0.5s;
}

.register-testimonial:hover {
    transform: translateY(-8px);
}

.register-testimonial-icon {
    color: #06b6d4;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.register-testimonial-text {
    font-size: 1.125rem;
    color: #fff;
    font-weight: 300;
    line-height: 1.7;
    margin-bottom: 1.5rem;
}

.register-testimonial-author {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.register-testimonial-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #334155;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
}

.register-testimonial-name {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
}

.register-testimonial-role {
    font-size: 12px;
    font-family: 'JetBrains Mono', monospace;
    color: #94a3b8;
}

/* Trust Logos */
.register-trust-logos {
    display: flex;
    gap: 2rem;
    margin-top: 3rem;
    opacity: 0.5;
    filter: grayscale(1);
}

.register-trust-item {
    height: 24px;
    width: 80px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 4px;
}

/* Navbar positioning for register page */
.register-cinematic .navbar-cinematic {
    position: relative;
}

/* Footer visible on register page */
.register-cinematic .footer-new {
    display: block;
}

/* Step 2 specific styles */
.register-step-animate {
    animation: registerSlideUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes registerSlideUp {
    0% { opacity: 0; transform: translateY(20px); }
    100% { opacity: 1; transform: translateY(0); }
}

.register-label-muted {
    color: #64748b !important;
}

.register-label-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 0.375rem;
}

.register-label-row .register-label {
    margin-bottom: 0;
}

.register-label-row .register-label-hint {
    font-size: 9px;
    color: #64748b;
}

.register-divider {
    width: 100%;
    height: 1px;
    background: rgba(255, 255, 255, 0.05);
    margin: 0.5rem 0;
}

.register-field-readonly {
    opacity: 0.7;
    transition: opacity 0.2s;
}

.register-field-readonly:hover {
    opacity: 1;
}

.register-input-disabled {
    background-color: #050b14 !important;
    color: #64748b !important;
    cursor: not-allowed;
    border-style: dashed;
}

.register-password-toggle {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: #64748b;
    cursor: pointer;
    padding: 0;
    transition: color 0.2s;
}

.register-password-toggle:hover {
    color: #fff;
}

.register-password-strength-text {
    font-size: 9px;
    color: #64748b;
    text-align: right;
    margin-top: 0.25rem;
}

/* Custom checkbox */
.register-checkbox {
    appearance: none;
    -webkit-appearance: none;
    background-color: #0b1221;
    border: 1px solid #1e293b;
    width: 16px;
    height: 16px;
    border-radius: 2px;
    display: inline-grid;
    place-content: center;
    margin-top: 3px;
    flex-shrink: 0;
    cursor: pointer;
    transition: all 0.2s;
}

.register-checkbox::before {
    content: "";
    width: 10px;
    height: 10px;
    transform: scale(0);
    transition: 120ms transform ease-in-out;
    box-shadow: inset 1em 1em #06b6d4;
    transform-origin: center;
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

.register-checkbox:checked::before {
    transform: scale(1);
}

.register-checkbox:checked {
    border-color: #06b6d4;
}

.register-consent-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
}

.register-consent-checkbox span {
    font-size: 12px;
    color: #94a3b8;
    line-height: 1.6;
    transition: color 0.2s;
}

.register-consent-checkbox:hover span {
    color: #cbd5e1;
}

.register-consent-checkbox a {
    color: #06b6d4;
    text-decoration: none !important;
}

.register-consent-checkbox a:hover {
    text-decoration: underline !important;
}

.register-btn-submit {
    margin-top: 1.5rem;
}

.register-btn-submit i {
    transition: transform 0.2s;
}

.register-btn-submit:hover i {
    transform: translateX(4px);
}

/* Visual column - center content */
.register-visual-center {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 5rem;
    z-index: 20;
}

.register-visual-badge {
    margin-bottom: 1.5rem;
}

.register-visual-badge span {
    display: inline-block;
    padding: 0.375rem 0.75rem;
    border-radius: 9999px;
    border: 1px solid rgba(6, 182, 212, 0.3);
    background: rgba(6, 182, 212, 0.1);
    color: #06b6d4;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
}

.register-visual-title {
    font-size: 2.25rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 1rem;
}

.register-visual-title span {
    color: #64748b;
}

.register-visual-desc {
    font-size: 14px;
    color: #94a3b8;
    max-width: 400px;
    line-height: 1.7;
    margin-bottom: 2rem;
}

/* Feature list */
.register-feature-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.register-feature-list li {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 14px;
    color: #cbd5e1;
}

.register-feature-icon {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #10b981;
    font-size: 12px;
    flex-shrink: 0;
}

/* Technical bar */
.register-tech-bar {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    background: rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(8px);
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 30;
}

.register-tech-info {
    display: flex;
    gap: 1rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #64748b;
}

.register-tech-status {
    color: #10b981;
}

.register-tech-dots {
    display: flex;
    gap: 0.5rem;
}

.register-tech-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #334155;
}

.register-tech-dot-active {
    background: #06b6d4;
    animation: techPulse 2s infinite;
}

@keyframes techPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* Responsive */
@media (max-width: 640px) {
    .register-field-row {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   LEGAL PAGE CINEMATIC STYLES
   ============================================ */

.legal-page-cinematic {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: #f8fafc;
    font-family: 'Inter', sans-serif;
    color: #1e293b;
}

/* Ensure all links in legal page are clickable */
.legal-page-cinematic a {
    pointer-events: auto;
    cursor: pointer;
}

/* Force grey background on body for legal pages */
body.landing-page:has(.legal-page-cinematic) {
    background-color: #f8fafc !important;
}

/* Legal Header */
.legal-header {
    background-color: #050b14;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding: 3rem 0;
    position: relative;
    overflow: hidden;
}

/* Public pages use fixed .tech-navbar (80px); offset the legal header so breadcrumbs/title aren't hidden under the logo */
.legal-page-cinematic.has-front-nav .legal-header {
    padding-top: calc(3rem + 80px);
}

.legal-header-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
                      linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.5;
    pointer-events: none;
}

.legal-header-content {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 10;
}

.legal-header-inner {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .legal-header-inner {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-end;
    }
}

.legal-header-left {
    flex: 1;
}

.legal-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 1rem;
}

.legal-breadcrumb a {
    color: #64748b;
    transition: color 0.2s;
    cursor: pointer;
    pointer-events: auto;
}

.legal-breadcrumb a:hover {
    color: #fff;
}

.legal-breadcrumb span:last-child {
    color: #06b6d4;
}

.legal-title {
    font-family: 'Inter', sans-serif;
    font-size: 1.875rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.5rem;
    line-height: 1.2;
    letter-spacing: -0.02em;
}

@media (min-width: 768px) {
    .legal-title {
        font-size: 2.25rem;
    }
}

.legal-subtitle {
    color: #94a3b8;
    font-size: 14px;
    font-weight: 300;
    margin: 0;
}

.legal-header-right {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
}

@media (min-width: 768px) {
    .legal-header-right {
        align-items: flex-end;
    }
}

.legal-meta-badges {
    display: flex;
    gap: 1rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #94a3b8;
}

.legal-meta-badge {
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.25rem 0.5rem;
    border-radius: 2px;
}

.legal-print-btn {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #fff;
    background: transparent;
    border: none;
    cursor: pointer;
    transition: color 0.2s;
}

.legal-print-btn:hover {
    color: #06b6d4;
}

/* Legal Container */
.legal-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 3rem 1.5rem;
    flex: 1;
    background-color: #f8fafc !important;
    position: relative;
    z-index: 1;
}

/* Ensure legal page wrapper has grey background */
.legal-page-cinematic .legal-container,
.legal-page-cinematic .legal-grid,
.legal-page-cinematic .legal-main {
    background-color: #f8fafc !important;
}

.legal-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
}

@media (min-width: 1024px) {
    .legal-grid {
        grid-template-columns: 3fr 7fr 2fr;
    }
}

/* Legal Sidebar */
.legal-sidebar {
    display: none;
}

@media (min-width: 1024px) {
    .legal-sidebar {
        display: block;
    }
}

.legal-sidebar-card {
    position: sticky;
    top: 6rem;
    border: 1px solid #e2e8f0;
    border-radius: 2px;
    background: #fff;
    padding: 1rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
    z-index: 1;
}

.legal-sidebar-label {
    display: block;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #94a3b8;
    padding: 0 0.75rem;
    margin-bottom: 1rem;
}

/* TOC Navigation */
.legal-toc {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.legal-toc-link {
    display: block;
    padding: 0.5rem 0.75rem;
    font-size: 12px;
    font-family: 'Inter', sans-serif;
    color: #64748b;
    border-left: 2px solid transparent;
    border-radius: 0 2px 2px 0;
    transition: all 0.2s;
    line-height: 1.4;
    cursor: pointer;
    position: relative;
    z-index: 1;
    pointer-events: auto;
}

.legal-toc-link:hover {
    background-color: #f8fafc;
    color: #0f172a;
}

.legal-toc-link.active {
    color: #06b6d4;
    border-left-color: #06b6d4;
    background-color: #f1f5f9;
    font-weight: 600;
}

/* Sidebar Support */
.legal-sidebar-support {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid #f1f5f9;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.legal-sidebar-support p {
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    color: #94a3b8;
    margin-bottom: 0.5rem;
}

.legal-sidebar-support a {
    font-size: 12px;
    font-weight: 700;
    color: #0f172a;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    transition: color 0.2s;
}

.legal-sidebar-support a:hover {
    color: #3b82f6;
}

/* Legal Main Content */
.legal-main {
    min-height: 600px;
}

.legal-main-full {
    grid-column: 1 / -1;
}

@media (min-width: 1024px) {
    .legal-main-full {
        grid-column: 1 / span 2;
    }
}

.legal-content {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 2px;
    padding: 2rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
    min-height: 500px;
    position: relative;
    z-index: 1;
}

@media (min-width: 768px) {
    .legal-content {
        padding: 3rem;
    }
}

/* Legal Content Typography - matching React project */
.legal-content {
    font-family: 'Inter', sans-serif;
}

.legal-content h2 {
    font-family: 'Inter', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: #0f172a;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    scroll-margin-top: 120px;
    letter-spacing: -0.01em;
}

/* Hide any H1 in content (title is in header) */
.legal-content h1 {
    display: none;
}

.legal-content h2:first-child {
    margin-top: 0;
}

.legal-content h3 {
    font-family: 'Inter', sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    color: #334155;
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
}

.legal-content p {
    font-family: 'Inter', sans-serif;
    margin-bottom: 1rem;
    line-height: 1.7;
    color: #475569;
    font-size: 0.95rem;
}

/* Lead paragraph */
.legal-content p.lead,
.legal-content > p:first-of-type {
    font-size: 0.875rem;
    font-weight: 500;
    color: #64748b;
    margin-bottom: 2rem;
}

.legal-content ul,
.legal-content ol {
    padding-left: 1.5rem;
    margin-bottom: 1rem;
    color: #475569;
    font-size: 0.95rem;
    font-family: 'Inter', sans-serif;
}

.legal-content ul {
    list-style-type: disc;
}

.legal-content ol {
    list-style-type: decimal;
}

.legal-content li {
    margin-bottom: 0.5rem;
    line-height: 1.6;
}

.legal-content strong {
    color: #0f172a;
    font-weight: 600;
}

.legal-content a {
    color: #0f172a;
    text-decoration: underline !important;
    text-decoration-color: #94a3b8 !important;
    cursor: pointer;
    position: relative;
    z-index: 1;
    pointer-events: auto;
}

.legal-content a:hover {
    color: #3b82f6;
    text-decoration-color: #3b82f6 !important;
}

/* Callout Box - IOD info style from React */
.legal-content .callout,
.legal-content blockquote {
    background-color: #f8fafc;
    border-left: 4px solid #0f172a;
    padding: 1rem;
    margin: 1.5rem 0;
}

.legal-content blockquote p,
.legal-content .callout p {
    margin-bottom: 0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    color: #64748b;
    line-height: 1.6;
}

.legal-content blockquote a,
.legal-content .callout a {
    color: #0f172a;
    font-weight: 700;
}

/* Table Styles - matching React project */
.legal-content table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
    margin: 1.5rem 0;
    border: 1px solid #e2e8f0;
    font-family: 'Inter', sans-serif;
}

.legal-content thead {
    background-color: #f1f5f9;
}

.legal-content th {
    padding: 0.75rem;
    text-align: left;
    font-weight: 700;
    color: #0f172a;
    text-transform: uppercase;
    font-size: 11px;
    border-bottom: 1px solid #e2e8f0;
}

.legal-content td {
    padding: 0.75rem;
    border-bottom: 1px solid #f1f5f9;
    color: #64748b;
}

.legal-content tbody tr:hover {
    background-color: #f8fafc;
}

/* Empty state */
.legal-empty {
    color: #94a3b8;
    font-style: italic;
    text-align: center;
    padding: 3rem;
}

/* Spacer column */
.legal-spacer {
    display: none;
}

@media (min-width: 1024px) {
    .legal-spacer {
        display: block;
    }
}

/* Print styles */
@media print {
    .legal-header-grid,
    .legal-sidebar,
    .legal-print-btn,
    .cinematic-navbar,
    .cinematic-footer {
        display: none !important;
    }
    
    .legal-header {
        background: #fff !important;
        color: #000 !important;
        border-bottom: 2px solid #000;
    }
    
    .legal-title {
        color: #000 !important;
    }
    
    .legal-content {
        border: none;
        box-shadow: none;
        padding: 0;
    }
    
    .legal-grid {
        display: block;
    }
}

/* ============================================
   LOGIN PAGE CINEMATIC STYLES
   ============================================ */

.login-cinematic {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: #020408;
    font-family: 'Inter', sans-serif;
}

.login-wrapper {
    display: flex;
    min-height: calc(100vh - 80px); /* Account for navbar - same as register */
}

/* Left Column - Form (IDENTICAL to register styles) */
.login-form-column {
    width: 100%;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background: #020408;
    position: relative;
    z-index: 10;
}

@media (min-width: 1024px) {
    .login-form-column {
        width: 50%;
        padding: 3rem;
    }
}

@media (min-width: 1280px) {
    .login-form-column {
        width: 41.666%;
        padding: 3rem 4rem;
    }
}

.login-form-container {
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.login-form-header {
    margin-bottom: 2rem;
}

.login-mono-label {
    display: block;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #06b6d4;
    margin-bottom: 0.5rem;
}

.login-title {
    font-family: 'Inter', sans-serif;
    font-size: 1.875rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.5rem;
}

.login-subtitle {
    font-size: 14px;
    color: #94a3b8;
}

/* Alerts */
.login-alert {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.75rem;
    border-radius: 2px;
    font-size: 12px;
    margin-bottom: 1.5rem;
}

.login-alert i {
    margin-top: 2px;
    flex-shrink: 0;
}

.login-alert-error {
    background-color: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.5);
    color: #f87171;
}

.login-alert-success {
    background-color: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.5);
    color: #34d399;
}

/* Form */
.login-form {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.login-field {
    display: flex;
    flex-direction: column;
}

.login-label {
    display: block;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 0.375rem;
}

.login-label-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.375rem;
}

.login-forgot-link {
    font-size: 10px;
    color: #06b6d4;
    transition: color 0.2s;
}

.login-forgot-link:hover {
    color: #fff;
}

.login-input-wrapper {
    position: relative;
}

.login-input-icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: #64748b;
    font-size: 12px;
}

.login-input {
    width: 100%;
    padding: 0.75rem 1rem 0.75rem 2.5rem;
    background-color: #0b1221;
    border: 1px solid #1e293b;
    border-radius: 2px;
    color: #fff;
    font-size: 14px;
    font-family: 'Inter', sans-serif;
    transition: all 0.2s;
}

.login-input::placeholder {
    color: #475569;
}

.login-input:focus {
    outline: none;
    border-color: #06b6d4;
    box-shadow: 0 0 0 1px rgba(6, 182, 212, 0.3);
    background-color: #0f172a;
}

/* Remember Me */
.login-remember {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.login-checkbox {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    background-color: #0b1221;
    border: 1px solid #1e293b;
    border-radius: 2px;
    cursor: pointer;
    display: inline-grid;
    place-content: center;
    flex-shrink: 0;
}

.login-checkbox::before {
    content: "";
    width: 10px;
    height: 10px;
    transform: scale(0);
    transition: 120ms transform ease-in-out;
    box-shadow: inset 1em 1em #06b6d4;
    transform-origin: center;
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

.login-checkbox:checked::before {
    transform: scale(1);
}

.login-remember-label {
    font-size: 12px;
    color: #94a3b8;
    cursor: pointer;
    transition: color 0.2s;
    user-select: none;
}

.login-remember-label:hover {
    color: #fff;
}

/* Submit Button */
.login-submit-btn {
    width: 100%;
    padding: 0.75rem;
    background-color: #06b6d4;
    color: #000;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: none;
    border-radius: 2px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    transition: all 0.2s;
    box-shadow: 0 0 20px rgba(6, 182, 212, 0.2);
    margin-top: 0.5rem;
}

.login-submit-btn:hover {
    background-color: #22d3ee;
}

/* Register Link */
.login-register-link {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    text-align: center;
}

.login-register-link p {
    font-size: 12px;
    color: #64748b;
    margin: 0;
}

.login-register-link a {
    color: #06b6d4;
    font-weight: 700;
    transition: color 0.2s;
}

.login-register-link a:hover {
    color: #fff;
}

/* Right Column - Visual (matching register styles) */
.login-visual-column {
    display: none;
    position: relative;
    overflow: hidden;
    background-color: #050b14;
}

@media (min-width: 1024px) {
    .login-visual-column {
        display: block;
        width: 50%;
    }
}

@media (min-width: 1280px) {
    .login-visual-column {
        width: 58.333%;
    }
}

.login-visual-bg {
    position: absolute;
    inset: 0;
}

.login-visual-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.3;
    filter: grayscale(100%) contrast(1.25);
}

.login-visual-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
                      linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.2;
    mix-blend-mode: overlay;
}

.login-visual-gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #020408, rgba(2, 4, 8, 0.4), transparent);
}

/* Status Widget */
.login-status-widget {
    position: absolute;
    bottom: 3rem;
    right: 3rem;
    background-color: rgba(15, 23, 42, 0.9);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1.5rem;
    border-radius: 2px;
    max-width: 280px;
}

.login-status-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding-bottom: 0.75rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.login-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #10b981;
    animation: pulse 2s infinite;
}

.login-status-header span {
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.login-status-info {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.login-status-row {
    display: flex;
    justify-content: space-between;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #94a3b8;
}

.login-status-value {
    color: #fff;
}

.login-status-active {
    color: #10b981;
}

/* ============================================
   TWO-FACTOR AUTH PAGE CINEMATIC STYLES
   ============================================ */

/* DEV Alert */
.twofa-dev-alert {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.15), rgba(245, 158, 11, 0.05));
    border: 1px solid rgba(245, 158, 11, 0.5);
    border-radius: 2px;
    padding: 1rem;
    margin-bottom: 1.5rem;
    text-align: center;
}

.twofa-dev-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    color: #f59e0b;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 0.75rem;
}

.twofa-dev-code {
    font-family: 'JetBrains Mono', monospace;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.3em;
    text-shadow: 0 0 20px rgba(245, 158, 11, 0.5);
}

.twofa-dev-expires {
    font-size: 10px;
    color: #94a3b8;
    margin-top: 0.5rem;
}

/* 2FA Code Input - extends login-input */
.twofa-code-input {
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.3em !important;
    text-align: center !important;
    padding-left: 2.5rem !important;
}

/* Hint text */
.login-hint {
    font-size: 11px;
    color: #64748b;
    margin-top: 0.5rem;
}

/* Action links for 2FA */
.login-action-link {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    background: transparent;
    border: none;
    color: #06b6d4;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: color 0.2s;
    padding: 0;
}

.login-action-link:hover {
    color: #fff;
}

/* 2FA Actions layout */
.twofa-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
}

.twofa-resend-form {
    display: contents;
}

/* Security Widget */
.twofa-security-widget {
    position: absolute;
    bottom: 3rem;
    right: 3rem;
    background-color: rgba(15, 23, 42, 0.9);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1.5rem;
    border-radius: 2px;
    max-width: 320px;
}

.twofa-widget-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.twofa-shield-icon {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, rgba(6, 182, 212, 0.2), rgba(6, 182, 212, 0.05));
    border: 1px solid rgba(6, 182, 212, 0.3);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #06b6d4;
    font-size: 18px;
}

.twofa-widget-header span {
    font-size: 13px;
    font-weight: 600;
    color: #fff;
}

.twofa-widget-content {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.twofa-feature {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 12px;
    color: #94a3b8;
}

.twofa-feature i {
    color: #10b981;
    font-size: 14px;
}

.twofa-widget-footer {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    font-size: 11px;
    color: #64748b;
}

.twofa-widget-footer i {
    color: #f59e0b;
    margin-top: 1px;
    flex-shrink: 0;
}

/* ============================================
   LOGOUT PAGE CINEMATIC STYLES
   ============================================ */

.logout-cinematic {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: #020408;
    font-family: 'Inter', sans-serif;
}

.logout-wrapper {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    padding: 2rem;
}

.logout-grid-bg {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
                      linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.1;
    pointer-events: none;
}

.logout-card {
    position: relative;
    z-index: 10;
    background-color: #0b1221;
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 3rem;
    border-radius: 2px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
    text-align: center;
    max-width: 28rem;
    width: 100%;
}

.logout-icon {
    width: 4rem;
    height: 4rem;
    background-color: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.5rem;
    color: #10b981;
    font-size: 1.875rem;
}

.logout-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.5rem;
}

.logout-text {
    font-size: 14px;
    color: #94a3b8;
    line-height: 1.6;
    margin-bottom: 2rem;
}

.logout-actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.logout-btn-primary {
    display: block;
    width: 100%;
    padding: 0.75rem;
    background-color: #fff;
    color: #000;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: 2px;
    text-align: center;
    transition: all 0.2s;
}

.logout-btn-primary:hover {
    background-color: #e2e8f0;
}

.logout-btn-secondary {
    display: block;
    width: 100%;
    padding: 0.75rem;
    background-color: transparent;
    color: #94a3b8;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 2px;
    text-align: center;
    transition: all 0.2s;
}

.logout-btn-secondary:hover {
    color: #fff;
    background-color: rgba(255, 255, 255, 0.05);
}

/* Feedback Section */
.logout-feedback {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.logout-feedback p {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 0.75rem;
}

.logout-feedback-buttons {
    display: flex;
    justify-content: center;
    gap: 1rem;
}

.logout-feedback-btn {
    font-size: 1.125rem;
    color: #475569;
    background: none;
    border: none;
    cursor: pointer;
    transition: all 0.2s;
}

.logout-feedback-btn:hover {
    transform: scale(1.1);
}

.logout-feedback-btn:nth-child(1):hover {
    color: #06b6d4;
}

.logout-feedback-btn:nth-child(2):hover {
    color: #fff;
}

.logout-feedback-btn:nth-child(3):hover {
    color: #f87171;
}

.logout-copyright {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #475569;
}

/* ============================================
   CATEGORY PAGE CINEMATIC STYLES
   ============================================ */

.category-cinematic {
    min-height: 100vh;
    background-color: #f8fafc;
    font-family: 'Inter', sans-serif;
}

/* Category Header */
.category-header {
    background-color: #050b14;
    padding: 5rem 0 4rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    position: relative;
    overflow: hidden;
}

.category-header-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
                      linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.5;
    pointer-events: none;
}

.category-header-content {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 10;
}

/* Category breadcrumbs use shared .blog-hero-meta-top, .blog-breadcrumb, .blog-meta-dot styles */

/* Category header uses blog animations */
.category-header .blog-hero-meta-top {
    animation: blogFadeUp 0.8s ease-out forwards;
}

.category-header-main {
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
    animation: blogFadeUp 0.8s ease-out 0.1s forwards;
    opacity: 0;
}

.category-icon {
    width: 64px;
    height: 64px;
    background: rgba(6, 182, 212, 0.1);
    border: 1px solid rgba(6, 182, 212, 0.3);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #06b6d4;
    font-size: 1.875rem;
    flex-shrink: 0;
}

.category-header-text {
    flex: 1;
}

.category-title {
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    margin: 0 0 0.75rem 0;
    letter-spacing: -0.02em;
}

@media (min-width: 768px) {
    .category-title {
        font-size: 2.5rem;
    }
}

.category-description {
    font-size: 14px;
    color: #94a3b8;
    max-width: 42rem;
    line-height: 1.6;
    margin: 0;
}

/* Main Content Area */
.category-main {
    background-color: #f8fafc;
    min-height: 100vh;
    padding: 3rem 0;
}

.category-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.category-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
}

@media (min-width: 1024px) {
    .category-grid {
        grid-template-columns: 2fr 1fr;
    }
}

/* Posts Column */
.category-posts-column {
    min-width: 0;
}

/* Toolbar */
.category-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #e2e8f0;
    gap: 1rem;
}

.category-count {
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    color: #64748b;
}

.category-count span {
    color: #0f172a;
    font-weight: 700;
}

.category-toolbar-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.category-sort {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 12px;
    color: #475569;
}

.category-sort-select {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    padding: 0.25rem 0.5rem;
    font-size: 12px;
    color: #0f172a;
    cursor: pointer;
}

.category-sort-select:focus {
    outline: none;
    border-color: #06b6d4;
}

.category-view-toggle {
    display: flex;
    gap: 0.25rem;
}

.category-view-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    color: #94a3b8;
    cursor: pointer;
    transition: all 0.2s;
}

.category-view-btn:hover {
    color: #0f172a;
}

.category-view-btn.active {
    background: #fff;
    color: #0f172a;
    border-color: #cbd5e1;
}

/* Posts Grid */
.category-posts-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .category-posts-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Post Card */
.category-post-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: all 0.3s ease;
}

.category-post-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    border-color: #3b82f6;
}

.category-post-image {
    height: 192px;
    background: #0f172a;
    position: relative;
    overflow: hidden;
}

.category-post-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(100%) contrast(1.1);
    opacity: 0.7;
    transition: all 0.5s ease;
}

.category-post-card:hover .category-post-image img {
    filter: grayscale(0%) contrast(1);
    opacity: 1;
    transform: scale(1.05);
}

.category-post-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    color: #334155;
    font-size: 3rem;
    transition: color 0.3s ease;
}

.category-post-card:hover .category-post-placeholder {
    color: #06b6d4;
}

.category-post-category {
    position: absolute;
    top: 1rem;
    left: 1rem;
    padding: 0.25rem 0.5rem;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(4px);
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    color: #0f172a;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.category-post-tag {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: rgba(6, 182, 212, 0.9);
    padding: 0.25rem 0.5rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    color: #000;
}

.category-post-content {
    padding: 1.5rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.category-post-date {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #94a3b8;
    margin-bottom: 0.5rem;
}

.category-post-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: #0f172a;
    margin: 0 0 0.75rem 0;
    line-height: 1.4;
}

.category-post-title a {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s;
}

.category-post-title a:hover {
    color: #3b82f6;
}

.category-post-excerpt {
    font-size: 12px;
    color: #64748b;
    line-height: 1.6;
    margin: 0 0 1.5rem 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.category-post-footer {
    margin-top: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 1rem;
    border-top: 1px solid #f1f5f9;
}

.category-post-author {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 10px;
    font-weight: 700;
    color: #475569;
}

.category-post-avatar {
    width: 20px;
    height: 20px;
    background: #e2e8f0;
    border-radius: 50%;
}

.category-post-link {
    font-size: 12px;
    font-weight: 700;
    color: #0f172a;
    text-decoration: none;
    transition: color 0.2s;
}

.category-post-link:hover {
    color: #3b82f6;
}

/* Pagination */
.category-pagination {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 3rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
}

.category-page-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e2e8f0;
    background: #fff;
    color: #475569;
    text-decoration: none;
    transition: all 0.2s;
}

.category-page-btn:hover:not(.disabled):not(.active) {
    background: #f1f5f9;
    color: #0f172a;
}

.category-page-btn.active {
    background: #0f172a;
    color: #fff;
    border-color: #0f172a;
}

.category-page-btn.disabled {
    color: #cbd5e1;
    cursor: not-allowed;
}

.category-page-dots {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #94a3b8;
}

/* Empty State */
.category-empty {
    text-align: center;
    padding: 4rem 2rem;
    color: #94a3b8;
}

.category-empty i {
    font-size: 3rem;
    margin-bottom: 1rem;
    display: block;
}

.category-empty p {
    margin: 0;
}

/* Sidebar */
.category-sidebar {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

/* Widget */
.category-widget {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    padding: 1.5rem;
}

.category-widget-title {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #94a3b8;
    margin: 0 0 1rem 0;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid #f1f5f9;
}

/* Category Navigation */
.category-nav {
    display: flex;
    flex-direction: column;
}

.category-nav-link {
    display: block;
    padding: 0.625rem 0.75rem;
    font-size: 12px;
    font-weight: 700;
    color: #475569;
    text-decoration: none;
    border-left: 2px solid transparent;
    border-radius: 0 4px 4px 0;
    transition: all 0.2s;
}

.category-nav-link:hover:not(.active) {
    background: #f1f5f9;
    color: #0f172a;
}

.category-nav-link.active {
    background: #0f172a;
    color: #fff;
    border-left-color: #06b6d4;
}

/* Tags */
.category-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.category-tag {
    padding: 0.25rem 0.5rem;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #475569;
    text-decoration: none;
    transition: all 0.2s;
}

.category-tag:hover {
    border-color: #06b6d4;
    color: #06b6d4;
}

.category-tag.active {
    background: #06b6d4;
    border-color: #06b6d4;
    color: #000;
}

/* Newsletter Widget */
.category-newsletter {
    background: #0f172a;
    padding: 1.5rem;
    border-radius: 4px;
    color: #fff;
    position: relative;
    overflow: hidden;
}

.category-newsletter-title {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #06b6d4;
    margin: 0 0 0.5rem 0;
}

.category-newsletter-text {
    font-size: 10px;
    color: #94a3b8;
    margin: 0 0 1rem 0;
    line-height: 1.5;
}

.category-newsletter-form {
    display: flex;
    gap: 0.5rem;
    position: relative;
    z-index: 1;
}

.category-newsletter-input {
    flex: 1;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 0.5rem 0.75rem;
    font-size: 12px;
    color: #fff;
}

.category-newsletter-input::placeholder {
    color: #64748b;
}

.category-newsletter-input:focus {
    outline: none;
    border-color: #06b6d4;
}

.category-newsletter-btn {
    background: #06b6d4;
    border: none;
    padding: 0.5rem 0.75rem;
    color: #000;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.2s;
}

.category-newsletter-btn:hover {
    background: #22d3ee;
}

.category-newsletter-icon {
    position: absolute;
    bottom: -0.5rem;
    right: -0.5rem;
    font-size: 4rem;
    color: rgba(255, 255, 255, 0.05);
    pointer-events: none;
}

/* ============================================
   BLOG INDEX CINEMATIC STYLES
   ============================================ */

.blog-index-cinematic {
    min-height: 100vh;
    background-color: #f8fafc;
    font-family: 'Inter', sans-serif;
}

/* Hero Section */
.blog-index-hero {
    background-color: #050b14;
    padding: 5rem 0 6rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    position: relative;
    overflow: hidden;
}

.blog-index-hero-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
                      linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.5;
    pointer-events: none;
}

.blog-index-hero-content {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 10;
}

.blog-index-hero-top {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    margin-bottom: 3rem;
}

@media (min-width: 1024px) {
    .blog-index-hero-top {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-end;
    }
}

.blog-index-hero-left {
    flex: 1;
}

.blog-index-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: #06b6d4;
    margin-bottom: 1rem;
}

.blog-index-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: #fff;
    margin: 0;
    letter-spacing: -0.02em;
}

@media (min-width: 768px) {
    .blog-index-title {
        font-size: 3rem;
    }
}

/* Search */
.blog-index-search {
    width: 100%;
    max-width: 400px;
}

.blog-index-search-wrapper {
    position: relative;
}

.blog-index-search-icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: #64748b;
    transition: color 0.2s;
}

.blog-index-search-wrapper:focus-within .blog-index-search-icon {
    color: #06b6d4;
}

.blog-index-search-input {
    width: 100%;
    padding: 0.75rem 1rem 0.75rem 2.5rem;
    background: #0f172a;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 4px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
    color: #fff;
    transition: all 0.2s;
}

.blog-index-search-input::placeholder {
    color: #64748b;
}

.blog-index-search-input:focus {
    outline: none;
    border-color: #06b6d4;
    box-shadow: 0 0 0 1px #06b6d4;
}

.blog-index-search-hint {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #475569;
    border: 1px solid #334155;
    padding: 0.125rem 0.375rem;
    border-radius: 2px;
}

/* Filters */
.blog-index-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding-top: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.blog-index-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1.25rem;
    background: rgba(15, 23, 42, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 4px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #94a3b8;
    text-decoration: none;
    transition: all 0.2s;
}

.blog-index-filter-btn i {
    font-size: 14px;
}

.blog-index-filter-btn:hover {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.3);
}

.blog-index-filter-btn.active {
    background: #0f172a;
    color: #fff;
    border-color: #0f172a;
}

/* Main Content */
.blog-index-main {
    background: #f8fafc;
    position: relative;
    z-index: 20;
    margin-top: -2.5rem;
}

.blog-index-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem 4rem 1.5rem;
}

/* Featured Row */
.blog-index-featured-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    margin-bottom: 3rem;
}

@media (min-width: 1024px) {
    .blog-index-featured-row {
        grid-template-columns: 2fr 1fr;
    }
}

/* Featured Card */
.blog-index-featured-card {
    display: block;
    position: relative;
    min-height: 450px;
    border-radius: 4px;
    overflow: hidden;
    text-decoration: none;
    background: #000;
}

.blog-index-featured-bg {
    position: absolute;
    inset: 0;
}

.blog-index-featured-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.7;
    filter: grayscale(100%);
    transition: all 0.7s ease;
}

.blog-index-featured-card:hover .blog-index-featured-bg img {
    filter: grayscale(0%);
    transform: scale(1.05);
}

.blog-index-featured-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.4) 50%, transparent 100%);
}

.blog-index-featured-content {
    position: relative;
    z-index: 10;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 2rem;
}

@media (min-width: 768px) {
    .blog-index-featured-content {
        padding: 2.5rem;
    }
}

.blog-index-featured-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.blog-index-featured-badge {
    background: #06b6d4;
    color: #000;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.25rem 0.75rem;
}

.blog-index-featured-date {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #cbd5e1;
}

.blog-index-featured-title {
    font-size: 1.75rem;
    font-weight: 700;
    color: #fff;
    margin: 0 0 1rem 0;
    line-height: 1.3;
    transition: color 0.2s;
}

@media (min-width: 768px) {
    .blog-index-featured-title {
        font-size: 2.25rem;
    }
}

.blog-index-featured-card:hover .blog-index-featured-title {
    color: #06b6d4;
}

.blog-index-featured-excerpt {
    font-size: 14px;
    color: #cbd5e1;
    line-height: 1.6;
    margin: 0 0 1.5rem 0;
    max-width: 600px;
}

.blog-index-featured-author {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.blog-index-featured-avatar {
    width: 24px;
    height: 24px;
    background: #06b6d4;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    color: #000;
}

.blog-index-featured-divider {
    color: #64748b;
}

/* Sidebar Column */
.blog-index-sidebar-col {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* Trending Card */
.blog-index-trending-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    padding: 1.5rem;
    text-decoration: none;
    transition: all 0.3s ease;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.blog-index-trending-card:hover {
    border-color: #06b6d4;
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.blog-index-trending-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
}

.blog-index-trending-tag {
    font-family: 'JetBrains Mono', monospace;
    font-size: 9px;
    text-transform: uppercase;
    color: #94a3b8;
    border: 1px solid #e2e8f0;
    padding: 0.125rem 0.375rem;
    border-radius: 2px;
}

.blog-index-trending-top i {
    color: #cbd5e1;
    transition: color 0.2s;
}

.blog-index-trending-card:hover .blog-index-trending-top i {
    color: #06b6d4;
}

.blog-index-trending-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: #0f172a;
    margin: 0 0 0.5rem 0;
    line-height: 1.4;
    transition: color 0.2s;
}

.blog-index-trending-card:hover .blog-index-trending-title {
    color: #3b82f6;
}

.blog-index-trending-excerpt {
    font-size: 12px;
    color: #64748b;
    margin: 0;
    line-height: 1.5;
}

/* Newsletter in sidebar */
.blog-index-newsletter {
    background: #0f172a;
    border-radius: 4px;
    padding: 1.5rem;
    color: #fff;
    position: relative;
    overflow: hidden;
}

.blog-index-newsletter-icon {
    position: absolute;
    top: 0;
    right: 0;
    padding: 0.5rem;
    opacity: 0.1;
    font-size: 4rem;
}

.blog-index-newsletter-title {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #06b6d4;
    margin: 0 0 0.5rem 0;
}

.blog-index-newsletter-text {
    font-size: 10px;
    color: #94a3b8;
    margin: 0 0 1rem 0;
    line-height: 1.5;
}

.blog-index-newsletter-form {
    display: flex;
    gap: 0.5rem;
    position: relative;
    z-index: 1;
}

.blog-index-newsletter-input {
    flex: 1;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 0.5rem 0.75rem;
    font-size: 12px;
    color: #fff;
}

.blog-index-newsletter-input::placeholder {
    color: #64748b;
}

.blog-index-newsletter-input:focus {
    outline: none;
    border-color: #06b6d4;
}

.blog-index-newsletter-btn {
    background: #06b6d4;
    border: none;
    padding: 0.5rem 0.75rem;
    color: #000;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.2s;
}

.blog-index-newsletter-btn:hover {
    background: #22d3ee;
}

/* Section Header */
.blog-index-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 1rem;
    margin-bottom: 2rem;
    margin-top: 3rem;
    border-bottom: 1px solid #e2e8f0;
}

.blog-index-section-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #0f172a;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.blog-index-section-bar {
    width: 8px;
    height: 32px;
    background: #3b82f6;
}

.blog-index-section-nav {
    display: flex;
    gap: 0.5rem;
}

.blog-index-nav-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e2e8f0;
    background: #fff;
    color: #475569;
    text-decoration: none;
    transition: all 0.2s;
}

.blog-index-nav-btn:hover:not(.disabled) {
    background: #f8fafc;
    border-color: #cbd5e1;
}

.blog-index-nav-btn.disabled {
    color: #cbd5e1;
    cursor: not-allowed;
}

/* Articles Grid */
.blog-index-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 768px) {
    .blog-index-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .blog-index-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Article Card */
.blog-index-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    overflow: hidden;
    transition: all 0.3s ease;
    position: relative;
}

.blog-index-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: #06b6d4;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

.blog-index-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    border-color: #06b6d4;
}

.blog-index-card:hover::before {
    transform: scaleX(1);
}

.blog-index-card-link {
    display: block;
    text-decoration: none;
    height: 100%;
}

.blog-index-card-image {
    height: 192px;
    background: #0f172a;
    position: relative;
    overflow: hidden;
}

.blog-index-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(100%) contrast(1.1);
    opacity: 0.7;
    transition: all 0.5s ease;
}

.blog-index-card:hover .blog-index-card-image img {
    filter: grayscale(0%) contrast(1);
    opacity: 1;
    transform: scale(1.05);
}

.blog-index-card-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    color: #334155;
    font-size: 3rem;
    transition: color 0.3s ease;
}

.blog-index-card:hover .blog-index-card-placeholder {
    color: #06b6d4;
}

.blog-index-card-badge {
    position: absolute;
    top: 1rem;
    left: 1rem;
    padding: 0.25rem 0.5rem;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(4px);
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    color: #0f172a;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.blog-index-card-content {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    height: calc(100% - 192px);
}

.blog-index-card-meta {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: #94a3b8;
    margin-bottom: 0.5rem;
}

.blog-index-card-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: #0f172a;
    margin: 0 0 0.75rem 0;
    line-height: 1.4;
    transition: color 0.2s;
}

.blog-index-card:hover .blog-index-card-title {
    color: #3b82f6;
}

.blog-index-card-excerpt {
    font-size: 12px;
    color: #64748b;
    line-height: 1.6;
    margin: 0 0 1.5rem 0;
    flex: 1;
}

.blog-index-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 1rem;
    border-top: 1px solid #f1f5f9;
    margin-top: auto;
}

.blog-index-card-author {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.blog-index-card-avatar {
    width: 20px;
    height: 20px;
    background: #e2e8f0;
    border-radius: 50%;
}

.blog-index-card-author span {
    font-size: 10px;
    font-weight: 700;
    color: #475569;
}

.blog-index-card-read {
    font-size: 12px;
    font-weight: 700;
    color: #0f172a;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    transition: transform 0.2s;
}

.blog-index-card-read i {
    color: #3b82f6;
}

.blog-index-card:hover .blog-index-card-read {
    transform: translateX(4px);
}

/* Load More */
.blog-index-load-more {
    margin-top: 4rem;
    text-align: center;
}

.blog-index-load-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 2rem;
    background: #fff;
    border: 1px solid #cbd5e1;
    color: #475569;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    text-decoration: none;
    transition: all 0.2s;
}

.blog-index-load-btn:hover {
    background: #f8fafc;
    border-color: #94a3b8;
    color: #0f172a;
}

/* Empty State */
.blog-index-empty {
    text-align: center;
    padding: 4rem 2rem;
    color: #94a3b8;
}

.blog-index-empty i {
    font-size: 3rem;
    margin-bottom: 1rem;
    display: block;
}

.blog-index-empty p {
    margin: 0;
}

