/* ============================================
   NOTIFICATORSMS - UPTIMELOCK STYLE
   ============================================ */

html, body { height: 100%; margin: 0; }

/* --- Hero Dark --- */
.ix-hero {
    background: linear-gradient(160deg, #0a101e 0%, #0f172a 45%, #0d1f3c 100%);
    padding: 7rem 0 5rem;
    overflow: hidden;
    position: relative;
}
.ix-hero-grid {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(56,189,248,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(56,189,248,.05) 1px, transparent 1px);
    background-size: 32px 32px;
    pointer-events: none;
}
.ix-hero-glow { position: absolute; border-radius: 50%; pointer-events: none; }
.ix-glow-1 { top: -120px; right: -80px; width: 480px; height: 480px; background: radial-gradient(circle, rgba(56,189,248,.12) 0%, transparent 65%); }
.ix-glow-2 { bottom: -80px; left: 10%; width: 350px; height: 350px; background: radial-gradient(circle, rgba(99,102,241,.1) 0%, transparent 65%); }

/* Badge intro */
.ix-intro-badge {
    display: inline-flex; align-items: center; gap: .5rem;
    font-size: .75rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
    color: #7dd3fc; background: rgba(56,189,248,.1); border: 1px solid rgba(56,189,248,.25);
    border-radius: 999px; padding: .35rem 1rem;
}
.ix-badge-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #38bdf8; box-shadow: 0 0 8px #38bdf8;
    animation: ix-blink 1.8s ease-in-out infinite;
}
@keyframes ix-blink { 0%,100% { opacity: 1; box-shadow: 0 0 8px #22c55e; } 50% { opacity: .4; box-shadow: 0 0 3px #22c55e; } }

/* Hero title */
.ix-hero-title { font-size: 2.6rem; font-weight: 800; line-height: 1.15; letter-spacing: -.03em; color: #f1f5f9; }
@media (min-width: 768px) { .ix-hero-title { font-size: 3.25rem; } }
@media (min-width: 992px) { .ix-hero-title { font-size: 3.75rem; } }
.ix-accent { background: linear-gradient(90deg, #38bdf8, #818cf8); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; font-weight: 800; }
.ix-hero-sub { font-size: 1.1rem; color: #94a3b8; max-width: 580px; line-height: 1.7; }
@media (min-width: 768px) { .ix-hero-sub { font-size: 1.2rem; } }

/* CTA Buttons */
.ix-btn-primary {
    display: inline-flex; align-items: center; justify-content: center;
    padding: .75rem 2.25rem; border-radius: .75rem;
    font-size: 1rem; font-weight: 700; color: #fff !important; text-decoration: none !important;
    background: linear-gradient(135deg, #1d4ed8, #38bdf8);
    box-shadow: 0 4px 24px rgba(56,189,248,.35);
    transition: transform .2s ease, box-shadow .2s ease; border: none; cursor: pointer;
}
.ix-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(56,189,248,.5); color: #fff !important; }

.ix-btn-ghost {
    display: inline-flex; align-items: center; justify-content: center;
    padding: .75rem 2rem; border-radius: .75rem;
    font-size: 1rem; font-weight: 600; color: #cbd5e1 !important; text-decoration: none !important;
    background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.15);
    transition: all .2s ease;
}
.ix-btn-ghost:hover { background: rgba(255,255,255,.12); color: #f1f5f9 !important; transform: translateY(-1px); }

/* Pills */
.ix-pill {
    display: inline-flex; align-items: center;
    font-size: .78rem; font-weight: 500; color: #94a3b8;
    background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
    border-radius: 999px; padding: .3rem .85rem; transition: border-color .2s;
}
.ix-pill:hover { border-color: rgba(56,189,248,.3); color: #cbd5e1; }

/* Feature cards */
.ix-feat-card {
    border-radius: 1rem; border: 1px solid rgba(0,0,0,.06);
    transition: box-shadow .25s ease, transform .25s ease; background: #fff;
}
.ix-feat-card:hover { box-shadow: 0 8px 30px rgba(37,99,235,.09); transform: translateY(-3px); }

/* Card lift */
.card-lift {
    border: 1px solid rgba(0,0,0,.07); border-radius: .75rem;
    transition: box-shadow .25s ease, transform .25s ease; background: #fff;
}
.card-lift:hover { box-shadow: 0 10px 40px rgba(37,99,235,.1); transform: translateY(-4px); }

/* Sections alternees */
section.bg-light-alt { background-color: #f8fafc !important; }

/* Tab nav */
.ix-tab-btn { background: transparent; cursor: pointer; transition: all .2s ease; position: relative; border: none !important; }
.ix-tab-btn:hover { background: rgba(0,0,0,.04); }
.ix-tab-btn.ix-tab-active { background: #fff; box-shadow: 0 2px 16px rgba(0,0,0,.08); }
.ix-tab-btn.ix-tab-active::before {
    content: ''; position: absolute; left: 0; top: 20%; bottom: 20%; width: 3px;
    border-radius: 0 3px 3px 0; background: #6c5ce7;
}
.ix-tab-pane { transition: opacity .3s ease; }

/* Stats section dark */
.ix-stats-section {
    background: linear-gradient(160deg, #0a101e 0%, #0f172a 55%, #0d1f3c 100%);
    position: relative; overflow: hidden;
}
.ix-stats-grid {
    position: absolute; inset: 0;
    background-image: linear-gradient(rgba(56,189,248,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(56,189,248,.04) 1px, transparent 1px);
    background-size: 40px 40px; pointer-events: none;
}
.ix-stats-glow-1 { position: absolute; top: -100px; right: -80px; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle, rgba(99,102,241,.12) 0%, transparent 65%); pointer-events: none; }
.ix-stats-glow-2 { position: absolute; bottom: -80px; left: 5%; width: 350px; height: 350px; border-radius: 50%; background: radial-gradient(circle, rgba(56,189,248,.08) 0%, transparent 65%); pointer-events: none; }

/* Trust line */
.ix-trust-line { border-top: 1px solid rgba(255,255,255,.07); padding-top: 2rem; }
.ix-trust-item { display: flex; align-items: center; gap: .5rem; }
.ix-trust-divider { width: 1px; height: 20px; background: rgba(255,255,255,.1); }

/* Notification handlers */
.ix-handler-card {
    background: #fff; border: 1px solid rgba(0,0,0,.06); border-radius: .75rem;
    padding: 1rem; text-align: center; transition: all .25s ease;
}
.ix-handler-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.1); transform: translateY(-3px); }
.ix-handler-card i { font-size: 1.8rem; }
.ix-handler-card .handler-name { font-size: .82rem; font-weight: 500; margin-top: .5rem; color: #374151; }

/* API code */
.ix-api-code {
    background: #0f172a; border: 1px solid rgba(255,255,255,.08); border-radius: 1rem;
    padding: 1.5rem; font-family: 'JetBrains Mono','Fira Code',monospace;
    font-size: .8rem; line-height: 1.85; color: #94a3b8; overflow-x: auto;
}
.ix-api-code .text-primary { color: #38bdf8 !important; }

/* FAQ */
.ix-faq .accordion-item { background: #fff; border: 1px solid rgba(0,0,0,.06) !important; border-radius: .75rem !important; margin-bottom: .5rem; }
.ix-faq .accordion-button { background: transparent; color: #1e293b; font-weight: 600; font-size: .9rem; padding: 1rem 1.15rem; box-shadow: none !important; }
.ix-faq .accordion-button:not(.collapsed) { color: #6c5ce7; }
.ix-faq .accordion-body { color: #475467; font-size: .85rem; padding: 0 1.15rem 1rem; line-height: 1.65; }

/* Testimonials */
.ix-testimonial-card {
    background: #fff; border: 1px solid rgba(0,0,0,.06); border-radius: 1rem;
    padding: 1.5rem; height: 100%; transition: all .25s ease;
}
.ix-testimonial-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.08); transform: translateY(-2px); }
.ix-testimonial-card .quote-mark { font-size: 2rem; color: #6c5ce7; line-height: 1; margin-bottom: .5rem; opacity: .35; }
.ix-testimonial-card .testimonial-text { font-size: .85rem; color: #475467; line-height: 1.65; margin-bottom: 1rem; }
.ix-testimonial-avatar { width: 36px; height: 36px; border-radius: 50%; border: 2px solid #e5e7eb; object-fit: cover; }
.ix-testimonial-name { font-weight: 600; font-size: .82rem; color: #1e293b; }
.ix-testimonial-role { font-size: .75rem; color: #94a3b8; }

/* CTA dark */
.ix-cta-section {
    background: linear-gradient(160deg, #0a101e 0%, #0f172a 55%, #0d1f3c 100%);
    position: relative; overflow: hidden; padding: 5rem 0;
}

/* Blog cards */
.ix-blog-card { background: #fff; border: 1px solid rgba(0,0,0,.06); border-radius: 1rem; overflow: hidden; height: 100%; transition: all .25s ease; }
.ix-blog-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.08); transform: translateY(-2px); }
.ix-blog-card img { width: 100%; height: 170px; object-fit: cover; }
.ix-blog-card .card-body { padding: 1.25rem; }
.ix-blog-card h3 { font-size: .92rem; font-weight: 600; margin-bottom: .3rem; }
.ix-blog-card h3 a { color: #1e293b; text-decoration: none; }
.ix-blog-card h3 a:hover { color: #6c5ce7; }
.ix-blog-card p { font-size: .82rem; color: #64748b; margin: 0; }

/* Footer dark */
.ix-footer {
    background: linear-gradient(160deg, #0a101e 0%, #0f172a 55%, #0d1f3c 100%);
    position: relative; padding: 3.5rem 0 0;
}
.ix-footer-grid {
    position: absolute; inset: 0;
    background-image: linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
    background-size: 60px 60px; pointer-events: none;
}
.ix-footer .container { position: relative; z-index: 1; }
.ft-captain-link { color: #94a3b8; text-decoration: none; font-size: .85rem; transition: color .2s ease; }
.ft-captain-link:hover { color: #38bdf8 !important; }
.ft-col-heading { color: #f1f5f9; font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 1rem; }
.ft-social-icon {
    width: 34px; height: 34px; border-radius: 8px;
    background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1);
    display: flex; align-items: center; justify-content: center;
    transition: all .2s ease; color: #94a3b8; text-decoration: none;
}
.ft-social-icon:hover { background: rgba(56,189,248,.15) !important; color: #38bdf8 !important; border-color: rgba(56,189,248,.3) !important; }
.ix-footer-bottom { margin-top: 2.5rem; padding: 1.1rem 0; border-top: 1px solid rgba(255,255,255,.07); text-align: center; }

/* Check items */
.ix-check-item { display: flex; align-items: start; gap: .75rem; margin-bottom: .35rem; }
.ix-check-dot {
    flex-shrink: 0; width: 20px; height: 20px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center; margin-top: 2px;
}
.ix-check-dot i { font-size: .6rem; }

/* Section badge pill */
.ix-section-badge {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .4rem .85rem; border-radius: 999px; width: fit-content;
}
.ix-section-badge-icon {
    width: 28px; height: 28px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
}
.ix-section-badge span { font-size: .8rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }

/* ============================================
   NAVBAR — BLANC (glassmorphism)
   ============================================ */
.hero-navbar {
    padding: .65rem 0;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
    z-index: 1050; transition: all .25s ease;
}
.hero-navbar-scrolled { background: rgba(255,255,255,.97); box-shadow: 0 2px 12px rgba(0,0,0,.08); }
.hero-navbar .navbar-brand img { max-height: 28px; }
.hero-navbar .nav-link { color: #334155 !important; font-size: .85rem; font-weight: 500; padding: .4rem .8rem !important; border-radius: 8px; transition: all .25s ease; }
.hero-navbar .nav-link:hover { color: #1d4ed8 !important; background: rgba(29,78,216,.05); }
.hero-navbar .navbar-toggler { border: 1px solid #d1d5db; }
.hero-navbar .navbar-toggler-icon { width: 1.1em; height: 1.1em; }
.btn-hero-primary { background: linear-gradient(135deg, #1d4ed8, #38bdf8); color: #fff !important; border: none; font-weight: 600; font-size: .82rem; padding: .45rem 1.1rem; border-radius: 8px; transition: all .25s ease; text-decoration: none; }
.btn-hero-primary:hover { color: #fff !important; box-shadow: 0 4px 20px rgba(56,189,248,.35); transform: translateY(-1px); }
.btn-hero-outline { background: #fff; color: #334155 !important; border: 1px solid #d1d5db; font-weight: 500; font-size: .82rem; padding: .45rem 1.1rem; border-radius: 8px; transition: all .25s ease; text-decoration: none; box-shadow: 0 1px 2px rgba(0,0,0,.04); }
.btn-hero-outline:hover { color: #1e293b !important; border-color: #94a3b8; box-shadow: 0 2px 8px rgba(0,0,0,.08); }

/* Responsive */
@media (max-width: 991.98px) {
    .ix-hero { padding: 6rem 0 3rem; }
    .hero-navbar .collapse { background: #fff; border-radius: .75rem; padding: .85rem; margin-top: .6rem; border: 1px solid #e2e8f0; box-shadow: 0 8px 30px rgba(0,0,0,.08); }
}
@media (max-width: 767.98px) { .ix-hero-title { font-size: 2rem; } }

/* Reveal */
.reveal-effect { visibility: hidden; }
.reveal-effect-prepared .reveal-effect-word { opacity: 0; filter: blur(6px); transform: translate3d(0,8px,0); display: inline-block; transition: opacity .5s ease, filter .5s ease, transform .5s ease; }
.reveal-effect-prepared.reveal-effect-in .reveal-effect-word { opacity: 1; filter: blur(0); transform: none; }

/* Body base */
.hero-body { font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: #fff; color: #1e293b; overflow-x: hidden; -webkit-font-smoothing: antialiased; line-height: 1.6; margin: 0; padding: 0; }