/* ==========================================================================
   DevOpsSchool — Shared UI Theme  (v3 — Courses-page design language)
   --------------------------------------------------------------------------
   Modeled on https://www.devopsschool.com/courses/ :
     • Dark navy TOP UTILITY BAR  (email · phone · currency · social · auth)
     • Clean WHITE MAIN NAVBAR    (DS logo · compact menu · rounded active pill)
     • Dark gradient/grid HERO    (headline · search box · category pills)
     • Dark enterprise FOOTER     (consistent with hero)
     • Floating WhatsApp CTA
   --------------------------------------------------------------------------
   COEXISTENCE: authored Tailwind-first with `preflight:false` + `container:false`.
   No global reset; every rule is scoped to #ds-navbar / #ds-footer / #ds-whatsapp
   or namespaced `.ds-*` helpers, so legacy Bootstrap-4 pages stay intact.
   ========================================================================== */

:root {
    /* Dark surfaces (topbar / hero / footer) */
    --ds-bg-1000: #060B16;
    --ds-bg-900:  #0B1120;
    --ds-bg-850:  #0E1729;
    --ds-bg-800:  #0F172A;
    --ds-bg-700:  #1E293B;
    --ds-line:    rgba(148, 163, 184, .14);
    --ds-line-strong: rgba(148, 163, 184, .26);

    /* Light navbar surfaces */
    --ds-nav-bg:        #FFFFFF;
    --ds-nav-text:      #334155;   /* slate-700 */
    --ds-nav-strong:    #0F172A;   /* slate-900 */
    --ds-nav-hover-bg:  #F1F5F9;   /* slate-100 */
    --ds-nav-line:      #E9EEF5;

    /* Brand accents */
    --ds-blue:        #2563EB;
    --ds-blue-bright: #3B82F6;
    --ds-indigo:      #6366F1;
    --ds-cyan:        #22D3EE;
    --ds-sky:         #38BDF8;
    --ds-wa:          #25D366;   /* WhatsApp green */

    /* Text on dark */
    --ds-text:    #E6EDF7;
    --ds-text-2:  #C2CCDC;
    --ds-muted:   #8C9AB4;
    --ds-muted-2: #6B7A93;

    /* Gradients */
    --ds-grad-brand: linear-gradient(135deg, #3B82F6 0%, #6366F1 45%, #22D3EE 100%);
    --ds-grad-cta:   linear-gradient(135deg, #2563EB 0%, #3B82F6 50%, #06B6D4 100%);
    --ds-grad-text:  linear-gradient(90deg, #93C5FD 0%, #C4B5FD 50%, #67E8F9 100%);

    /* Shadows */
    --ds-shadow-cta:   0 10px 30px -10px rgba(37, 99, 235, .6);
    --ds-shadow-nav:   0 1px 0 0 var(--ds-nav-line), 0 8px 24px -16px rgba(2, 6, 23, .25);
    --ds-shadow-soft:  0 18px 48px -24px rgba(2, 6, 23, .85);
    --ds-shadow-pop:   0 24px 50px -18px rgba(2, 6, 23, .28), 0 8px 16px -10px rgba(2, 6, 23, .12);

    /* Layout metrics — md+ shows the 38px top strip above the 68px white main bar */
    --ds-header-h:    106px;   /* md+: top strip (38) + main bar (68) */
    --ds-header-h-m:  68px;    /* < md: main bar only                */
    --ds-radius:      16px;
    --ds-ease:        cubic-bezier(.22, 1, .36, 1);
}

/* --------------------------------------------------------------------------
   1. Fixed-header offset (host page body)
   -------------------------------------------------------------------------- */
body.ds-shell-body { padding-top: var(--ds-header-h-m); }
body.ds-no-scroll  { overflow: hidden; }
@media (min-width: 768px) { body.ds-shell-body { padding-top: var(--ds-header-h); } }

/* --------------------------------------------------------------------------
   2. Scoped base reset (preflight is OFF)
   -------------------------------------------------------------------------- */
#ds-navbar, #ds-navbar *,
#ds-footer, #ds-footer *,
#ds-whatsapp, #ds-whatsapp * { box-sizing: border-box; }

#ds-navbar, #ds-footer, #ds-whatsapp {
    font-family: 'Inter', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', sans-serif;
    -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
#ds-navbar a, #ds-footer a { text-decoration: none; color: inherit; }
#ds-navbar ul, #ds-footer ul { list-style: none; margin: 0; padding: 0; }
#ds-navbar button { font-family: inherit; cursor: pointer; }
#ds-navbar h1, #ds-navbar h2, #ds-footer h2, #ds-footer h3 { margin: 0; }
[x-cloak] { display: none !important; }

.material-symbols-rounded {
    font-family: 'Material Symbols Rounded';
    font-weight: normal; font-style: normal; line-height: 1; letter-spacing: normal;
    text-transform: none; display: inline-block; white-space: nowrap; direction: ltr;
    -webkit-font-smoothing: antialiased; font-feature-settings: 'liga'; user-select: none;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

/* --------------------------------------------------------------------------
   3. Header wrapper (fixed) + TOP UTILITY BAR (dark navy)
   -------------------------------------------------------------------------- */
#ds-navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 1080; }

.ds-topbar {
    background: linear-gradient(90deg, var(--ds-bg-1000), var(--ds-bg-850) 55%, var(--ds-bg-900));
    color: var(--ds-text-2);
    border-bottom: 1px solid rgba(148, 163, 184, .1);
    font-size: 12.5px;
}
.ds-topbar a { color: var(--ds-text-2); transition: color .15s var(--ds-ease); }
.ds-topbar a:hover { color: #fff; }
.ds-topbar .ds-tb-item { display: inline-flex; align-items: center; gap: 6px; }
.ds-topbar .ds-tb-sep { width: 1px; height: 16px; background: rgba(148, 163, 184, .22); }

/* Currency + social on dark topbar */
.ds-tb-select {
    display: inline-flex; align-items: center; gap: 4px; padding: 5px 10px; border-radius: 8px;
    background: rgba(148, 163, 184, .08); border: 1px solid rgba(148, 163, 184, .16);
    color: var(--ds-text-2); font-size: 12px; font-weight: 600; transition: background .15s, color .15s;
}
.ds-tb-select:hover { background: rgba(148, 163, 184, .16); color: #fff; }
.ds-tb-social {
    display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px;
    border-radius: 7px; color: var(--ds-text-2);
    background: rgba(148, 163, 184, .08); transition: background .15s, color .15s, transform .15s;
}
.ds-tb-social:hover { background: var(--ds-grad-cta); color: #fff; transform: translateY(-1px); }

/* Currency dropdown menu */
.ds-tb-menu {
    background: var(--ds-bg-800); border: 1px solid var(--ds-line-strong); border-radius: 12px;
    box-shadow: var(--ds-shadow-soft); padding: 6px; min-width: 150px;
}
.ds-tb-menu a { display: block; padding: 8px 12px; border-radius: 8px; font-size: 13px; color: var(--ds-text-2); }
.ds-tb-menu a:hover { background: rgba(59, 130, 246, .16); color: #fff; }

/* --------------------------------------------------------------------------
   4. MAIN NAVBAR (clean white) + brand
   -------------------------------------------------------------------------- */
.ds-mainbar {
    background: var(--ds-nav-bg);
    border-bottom: 1px solid var(--ds-nav-line);
    box-shadow: var(--ds-shadow-nav);
}
#ds-navbar.ds-scrolled .ds-mainbar { box-shadow: 0 6px 24px -12px rgba(2, 6, 23, .25); }

.ds-brand-badge {
    display: inline-flex; align-items: center; justify-content: center;
    width: 42px; height: 42px; border-radius: 12px; background: var(--ds-grad-brand);
    box-shadow: 0 8px 22px -8px rgba(59, 130, 246, .7), inset 0 0 0 1px rgba(255, 255, 255, .18);
    color: #fff; flex-shrink: 0;
}
.ds-brand-name { font-weight: 800; letter-spacing: -.02em; line-height: 1; color: var(--ds-nav-strong); }
.ds-brand-name .ds-accent {
    background: var(--ds-grad-cta); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.ds-brand-tag { color: #64748B; font-size: 11px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; }

/* Compact menu links with ROUNDED active/hover pill */
.ds-nav-link {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 8px 11px; border-radius: 9999px;
    font-size: 13.5px; font-weight: 600; color: var(--ds-nav-text);
    transition: color .18s var(--ds-ease), background .18s var(--ds-ease);
    white-space: nowrap;
}
@media (min-width: 1536px) { .ds-nav-link { padding: 9px 14px; font-size: 14px; } }
.ds-nav-link:hover { color: var(--ds-blue); background: var(--ds-nav-hover-bg); }
.ds-nav-link.ds-active {
    color: #fff; background: var(--ds-grad-cta);
    box-shadow: 0 8px 18px -8px rgba(37, 99, 235, .55);
}
.ds-nav-link.ds-active:hover { color: #fff; }
.ds-nav-link:focus-visible { outline: 2px solid var(--ds-blue-bright); outline-offset: 2px; }

/* --------------------------------------------------------------------------
   5. Buttons
   -------------------------------------------------------------------------- */
.ds-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    font-weight: 700; font-size: 14px; line-height: 1; border-radius: 11px; padding: 10px 16px;
    transition: transform .18s var(--ds-ease), box-shadow .25s var(--ds-ease), background .25s var(--ds-ease), border-color .2s var(--ds-ease), color .2s;
    white-space: nowrap; border: 1px solid transparent;
}
.ds-btn:focus-visible { outline: 2px solid var(--ds-blue-bright); outline-offset: 2px; }
.ds-btn-primary { color: #fff; background: var(--ds-grad-cta); box-shadow: var(--ds-shadow-cta); background-size: 160% 160%; }
.ds-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 16px 38px -12px rgba(37, 99, 235, .8); background-position: 100% 50%; }

/* Light variants (on white navbar) */
.ds-btn-line { color: var(--ds-nav-strong); background: #fff; border-color: var(--ds-nav-line); }
.ds-btn-line:hover { color: var(--ds-blue); border-color: #BFD3F5; background: var(--ds-nav-hover-bg); transform: translateY(-1px); }

/* Dark variants (on dark surfaces) */
.ds-btn-ghost { color: var(--ds-text); background: rgba(148, 163, 184, .1); border-color: var(--ds-line-strong); }
.ds-btn-ghost:hover { color: #fff; background: rgba(148, 163, 184, .18); transform: translateY(-1px); }
.ds-btn-soft { color: #1d4ed8; background: #EAF1FE; border-color: #D5E3FC; }
.ds-btn-soft:hover { color: #1e40af; background: #DCE8FD; }

/* Icon button on white bar */
.ds-icon-btn {
    display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px;
    border-radius: 11px; color: var(--ds-nav-strong); background: #fff; border: 1px solid var(--ds-nav-line);
    transition: background .18s, color .18s, border-color .18s;
}
.ds-icon-btn:hover { background: var(--ds-nav-hover-bg); color: var(--ds-blue); border-color: #BFD3F5; }
.ds-icon-btn:focus-visible { outline: 2px solid var(--ds-blue-bright); outline-offset: 2px; }

/* --------------------------------------------------------------------------
   6. Dropdown / Mega-menu (LIGHT, under white navbar)
   -------------------------------------------------------------------------- */
.ds-pop {
    background: #fff; border: 1px solid var(--ds-nav-line); border-radius: 16px;
    box-shadow: var(--ds-shadow-pop); overflow: hidden;
}
.ds-pop::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--ds-grad-cta); }
.ds-pop-label { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .14em; color: #94A3B8; }
.ds-mega-link {
    display: flex; gap: 12px; align-items: flex-start; padding: 11px 14px; border-radius: 12px;
    transition: background .16s var(--ds-ease), transform .16s var(--ds-ease);
}
.ds-mega-link:hover { background: var(--ds-nav-hover-bg); transform: translateX(2px); }
.ds-mega-ico {
    display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
    width: 38px; height: 38px; border-radius: 10px; color: var(--ds-blue);
    background: #EAF1FE; border: 1px solid #D8E5FC;
}
.ds-mega-title { font-size: 13.5px; font-weight: 700; color: var(--ds-nav-strong); line-height: 1.2; }
.ds-mega-desc  { font-size: 12px; color: #64748B; margin-top: 2px; line-height: 1.35; }
.ds-mega-promo-light {
    background: radial-gradient(120% 140% at 0% 0%, #EAF1FE, #F8FBFF 70%);
    border: 1px solid #D8E5FC; border-radius: 14px;
}
.ds-pill-light {
    display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; border-radius: 999px;
    font-size: 12px; font-weight: 700; color: #1d4ed8; background: #EAF1FE; border: 1px solid #D8E5FC;
}
.ds-scroll::-webkit-scrollbar { width: 8px; }
.ds-scroll::-webkit-scrollbar-thumb { background: rgba(148, 163, 184, .35); border-radius: 8px; }

/* Search overlay (light) */
.ds-search-wrap { background: #fff; border-bottom: 1px solid var(--ds-nav-line); box-shadow: var(--ds-shadow-pop); }
.ds-search-input { color: var(--ds-nav-strong); background: transparent; }
.ds-search-input::placeholder { color: #94A3B8; }

/* --------------------------------------------------------------------------
   7. Mobile drawer (light, matches white navbar)
   -------------------------------------------------------------------------- */
.ds-drawer { background: #fff; border-left: 1px solid var(--ds-nav-line); }
.ds-drawer-link {
    display: flex; align-items: center; justify-content: space-between; gap: 10px; width: 100%;
    padding: 13px 16px; border-radius: 12px; color: var(--ds-nav-text); font-size: 15px; font-weight: 600;
    transition: background .16s, color .16s;
}
.ds-drawer-link:hover, .ds-drawer-link.ds-active { color: var(--ds-blue); background: var(--ds-nav-hover-bg); }
.ds-drawer-sub a { display: block; padding: 10px 14px; border-radius: 10px; font-size: 13.5px; color: #64748B; transition: color .15s, background .15s; }
.ds-drawer-sub a:hover { color: var(--ds-blue); background: var(--ds-nav-hover-bg); }

/* --------------------------------------------------------------------------
   8. HERO — dark gradient + grid, search box, category pills
   -------------------------------------------------------------------------- */
.ds-hero {
    position: relative; overflow: hidden;
    background:
        radial-gradient(60% 80% at 50% -10%, rgba(37, 99, 235, .28), transparent 60%),
        radial-gradient(50% 60% at 90% 0%, rgba(34, 211, 238, .14), transparent 55%),
        linear-gradient(180deg, var(--ds-bg-1000) 0%, #070D1A 70%, var(--ds-bg-1000) 100%);
    color: var(--ds-text);
}
.ds-grid-overlay {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(148, 163, 184, .07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(148, 163, 184, .07) 1px, transparent 1px);
    background-size: 46px 46px;
    -webkit-mask-image: radial-gradient(75% 65% at 50% 25%, #000 30%, transparent 78%);
    mask-image: radial-gradient(75% 65% at 50% 25%, #000 30%, transparent 78%);
}
.ds-glow { filter: blur(70px); opacity: .55; }
.ds-gradient-text { background: var(--ds-grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* Hero search box */
.ds-searchbox {
    display: flex; align-items: center; gap: 10px; width: 100%;
    background: rgba(255, 255, 255, .06); border: 1px solid var(--ds-line-strong); border-radius: 16px;
    padding: 8px 8px 8px 18px; -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
    box-shadow: var(--ds-shadow-soft);
}
.ds-searchbox input {
    flex: 1 1 auto; background: transparent; border: 0; outline: none;
    color: #fff; font-size: 15px; padding: 12px 0;
}
.ds-searchbox input::placeholder { color: var(--ds-muted); }

/* Category filter pills */
.ds-cat {
    display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; border-radius: 999px;
    font-size: 13.5px; font-weight: 600; color: var(--ds-text-2);
    background: rgba(148, 163, 184, .08); border: 1px solid var(--ds-line);
    transition: color .18s, background .18s, border-color .18s, transform .18s;
}
.ds-cat:hover { color: #fff; background: rgba(59, 130, 246, .16); border-color: rgba(59, 130, 246, .35); transform: translateY(-1px); }
.ds-cat.ds-cat-active { color: #fff; background: var(--ds-grad-cta); border-color: transparent; box-shadow: var(--ds-shadow-cta); }

/* --------------------------------------------------------------------------
   9. Footer (dark, consistent with hero)
   -------------------------------------------------------------------------- */
#ds-footer {
    position: relative; color: var(--ds-text-2);
    background:
        radial-gradient(80% 120% at 85% -10%, rgba(99, 102, 241, .18), transparent 55%),
        radial-gradient(70% 120% at 5% 0%, rgba(34, 211, 238, .12), transparent 50%),
        linear-gradient(180deg, var(--ds-bg-900) 0%, var(--ds-bg-1000) 100%);
    border-top: 1px solid var(--ds-line); overflow: hidden;
}
#ds-footer::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(59, 130, 246, .6), rgba(34, 211, 238, .4), transparent); }
.ds-foot-h { font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: #fff; margin-bottom: 18px; display: inline-flex; align-items: center; gap: 8px; }
.ds-foot-h::before { content: ""; width: 16px; height: 2px; border-radius: 2px; background: var(--ds-grad-cta); }
.ds-foot-link { position: relative; display: inline-flex; align-items: center; gap: 7px; font-size: 13.5px; color: var(--ds-muted); line-height: 1.5; transition: color .18s var(--ds-ease); }
.ds-foot-link .ds-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--ds-line-strong); transition: background .18s, transform .18s; flex-shrink: 0; }
.ds-foot-link:hover { color: #fff; }
.ds-foot-link:hover .ds-dot { background: var(--ds-cyan); transform: scale(1.5); }
.ds-chip { display: inline-flex; align-items: center; gap: 7px; padding: 7px 14px; border-radius: 999px; font-size: 12.5px; font-weight: 600; color: var(--ds-text-2); background: rgba(148, 163, 184, .07); border: 1px solid var(--ds-line); transition: color .2s, background .2s, border-color .2s; }
.ds-chip:hover { color: #fff; background: rgba(59, 130, 246, .14); border-color: rgba(59, 130, 246, .35); }
.ds-chip .ds-chip-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--ds-grad-cta); }
.ds-social { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 12px; color: var(--ds-text-2); background: rgba(148, 163, 184, .08); border: 1px solid var(--ds-line); transition: transform .18s var(--ds-ease), color .2s, background .2s, border-color .2s; }
.ds-social:hover { transform: translateY(-2px); color: #fff; background: var(--ds-grad-cta); border-color: transparent; box-shadow: var(--ds-shadow-cta); }
.ds-acc-btn .ds-acc-ico { transition: transform .25s var(--ds-ease); }
.ds-acc-btn[aria-expanded="true"] .ds-acc-ico { transform: rotate(180deg); }

/* --------------------------------------------------------------------------
   10. Page helpers (dark) — cards, pills used by demo/examples
   -------------------------------------------------------------------------- */
.ds-page {
    background:
        radial-gradient(60% 80% at 50% -10%, rgba(37, 99, 235, .14), transparent 60%),
        linear-gradient(180deg, var(--ds-bg-1000) 0%, #070D1A 60%, var(--ds-bg-1000) 100%);
    color: var(--ds-text); font-family: 'Inter', ui-sans-serif, system-ui, sans-serif; min-height: 100vh;
}
.ds-pill { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 999px; font-size: 12.5px; font-weight: 600; color: #bfdbfe; background: rgba(37, 99, 235, .12); border: 1px solid rgba(59, 130, 246, .3); }
.ds-stat-card, .ds-feature-card {
    background: linear-gradient(180deg, rgba(30, 41, 59, .55), rgba(15, 23, 42, .55));
    border: 1px solid var(--ds-line); border-radius: var(--ds-radius);
    transition: transform .25s var(--ds-ease), border-color .25s var(--ds-ease), box-shadow .25s var(--ds-ease), background .25s;
}
.ds-feature-card:hover { transform: translateY(-4px); border-color: rgba(59, 130, 246, .45); box-shadow: var(--ds-shadow-soft); background: linear-gradient(180deg, rgba(37, 99, 235, .14), rgba(15, 23, 42, .55)); }
/* Dark promo card (footer CTA, enterprise panel) */
.ds-mega-promo {
    background: radial-gradient(120% 140% at 0% 0%, rgba(59, 130, 246, .26), transparent 60%), var(--ds-bg-800);
    border: 1px solid rgba(59, 130, 246, .28); border-radius: 16px;
}

/* --------------------------------------------------------------------------
   11. Floating WhatsApp CTA
   -------------------------------------------------------------------------- */
#ds-whatsapp {
    position: fixed; right: 22px; bottom: 22px; z-index: 1090;
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--ds-wa); color: #fff; font-weight: 700; font-size: 14px;
    padding: 12px 18px 12px 14px; border-radius: 999px;
    box-shadow: 0 14px 34px -10px rgba(37, 211, 102, .6), 0 4px 10px rgba(0, 0, 0, .2);
    transition: transform .2s var(--ds-ease), box-shadow .2s var(--ds-ease);
}
#ds-whatsapp:hover { transform: translateY(-2px) scale(1.02); box-shadow: 0 20px 44px -10px rgba(37, 211, 102, .75); }
#ds-whatsapp .ds-wa-ico { display: inline-flex; }
#ds-whatsapp .ds-wa-ico::after {
    content: ""; position: absolute; width: 48px; height: 48px; border-radius: 999px;
    border: 2px solid var(--ds-wa); left: 9px; bottom: 9px; opacity: .55; animation: ds-wa-pulse 2.4s ease-out infinite;
}
.ds-wa-label { display: none; }
@media (min-width: 640px) { .ds-wa-label { display: inline; } }
@keyframes ds-wa-pulse { 0% { transform: scale(.85); opacity: .55; } 100% { transform: scale(1.5); opacity: 0; } }

/* --------------------------------------------------------------------------
   12. Animations + a11y
   -------------------------------------------------------------------------- */
@keyframes ds-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@keyframes ds-fade-up { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
.ds-anim-float { animation: ds-float 7s ease-in-out infinite; }
.ds-anim-up { animation: ds-fade-up .7s var(--ds-ease) both; }

@media (prefers-reduced-motion: reduce) {
    #ds-navbar *, #ds-footer *, #ds-whatsapp *, .ds-page *, .ds-hero * { animation: none !important; transition: none !important; }
    #ds-whatsapp .ds-wa-ico::after { display: none; }
}
#ds-navbar, #ds-footer { max-width: 100vw; }

/* ==========================================================================
   13. NAVBAR PREMIUM UPGRADES (v3.1) — navbar-scoped only
   Refines the header to enterprise-platform quality without touching hero/footer.
   ========================================================================== */
#ds-navbar { isolation: isolate; }

/* Condense-on-scroll: frosted glass white bar + glowing gradient underline */
.ds-mainbar { position: relative; transition: background .3s var(--ds-ease), box-shadow .3s var(--ds-ease); }
.ds-mainbar::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 1px; pointer-events: none;
    background: linear-gradient(90deg, transparent, rgba(37, 99, 235, .5), rgba(34, 211, 238, .38), transparent);
    opacity: 0; transition: opacity .35s var(--ds-ease);
}
#ds-navbar.ds-scrolled .ds-mainbar {
    background: rgba(255, 255, 255, .82);
    -webkit-backdrop-filter: saturate(165%) blur(12px); backdrop-filter: saturate(165%) blur(12px);
    box-shadow: 0 10px 34px -16px rgba(2, 6, 23, .3);
}
#ds-navbar.ds-scrolled .ds-mainbar::after { opacity: .9; }

/* Brand badge soft glow ring (on hover) */
.ds-brand-badge { position: relative; }
.ds-brand-badge::after {
    content: ""; position: absolute; inset: -3px; border-radius: 15px; z-index: -1;
    background: var(--ds-grad-brand); opacity: 0; filter: blur(9px); transition: opacity .3s var(--ds-ease);
}
.group:hover .ds-brand-badge::after { opacity: .5; }

/* Refined nav pills — hover ring + active inner highlight */
.ds-nav-link { position: relative; }
.ds-nav-link:hover { box-shadow: inset 0 0 0 1px rgba(37, 99, 235, .16); }
.ds-nav-link.ds-active { box-shadow: 0 8px 18px -8px rgba(37, 99, 235, .55), inset 0 1px 0 rgba(255, 255, 255, .28); }

/* Premium search trigger (pill) + keyboard hint */
.ds-search-trigger {
    display: inline-flex; align-items: center; gap: 9px; height: 42px; padding: 0 9px 0 13px;
    border-radius: 12px; border: 1px solid var(--ds-nav-line); background: #fff; color: #64748B;
    font-size: 13px; font-weight: 600; min-width: 168px; justify-content: space-between;
    transition: border-color .18s, background .18s, color .18s, box-shadow .18s;
}
.ds-search-trigger:hover { color: var(--ds-blue); border-color: #BFD3F5; background: var(--ds-nav-hover-bg); box-shadow: 0 6px 16px -10px rgba(37, 99, 235, .4); }
.ds-search-trigger:focus-visible { outline: 2px solid var(--ds-blue-bright); outline-offset: 2px; }
.ds-kbd {
    display: inline-flex; align-items: center; gap: 1px; padding: 2px 7px; border-radius: 7px; font-size: 11px;
    font-weight: 800; color: #64748B; background: #F1F5F9; border: 1px solid var(--ds-nav-line); box-shadow: 0 1px 0 var(--ds-nav-line);
}

/* CTA sheen + arrow slide */
.ds-btn-primary { position: relative; overflow: hidden; }
.ds-btn-primary::after {
    content: ""; position: absolute; top: 0; bottom: 0; left: -65%; width: 42%;
    background: linear-gradient(100deg, transparent, rgba(255, 255, 255, .5), transparent); transform: skewX(-18deg); pointer-events: none;
}
.ds-btn-primary:hover::after { animation: ds-sheen .9s var(--ds-ease); }
@keyframes ds-sheen { from { left: -65%; } to { left: 145%; } }
.ds-cta-arrow { transition: transform .2s var(--ds-ease); }
.ds-btn-primary:hover .ds-cta-arrow { transform: translateX(3px); }

/* Mega-menu: colored icon tiles */
.ds-tile { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0; border: 1px solid transparent; }
.ds-tile-blue    { color: #2563EB; background: #EAF1FE; border-color: #D8E5FC; }
.ds-tile-violet  { color: #7C3AED; background: #F1ECFE; border-color: #E4D8FB; }
.ds-tile-cyan    { color: #0891B2; background: #E6F7FB; border-color: #CBEDF5; }
.ds-tile-emerald { color: #059669; background: #E6F6EF; border-color: #C9ECDB; }
.ds-tile-amber   { color: #D97706; background: #FEF3E2; border-color: #FBE3C2; }
.ds-tile-rose    { color: #E11D48; background: #FDEAEF; border-color: #F8D2DC; }

/* Mega-menu: bottom quick-links bar */
.ds-pop-foot {
    display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
    margin: 8px -16px -16px; padding: 12px 18px; border-top: 1px solid var(--ds-nav-line);
    background: linear-gradient(180deg, #FBFCFE, #F4F8FE);
}
.ds-pop-foot .ds-foot-quick { display: inline-flex; align-items: center; gap: 14px; }
.ds-pop-foot a { font-size: 12.5px; font-weight: 600; color: #64748B; transition: color .15s; }
.ds-pop-foot a:hover { color: var(--ds-blue); }

/* Top utility bar: live announcement chip */
.ds-tb-promo {
    display: inline-flex; align-items: center; gap: 8px; padding: 4px 13px; border-radius: 999px; font-weight: 600;
    color: #dbe6fb; background: linear-gradient(90deg, rgba(37, 99, 235, .24), rgba(34, 211, 238, .14));
    border: 1px solid rgba(59, 130, 246, .32); transition: color .18s, border-color .18s;
}
.ds-tb-promo:hover { color: #fff; border-color: rgba(59, 130, 246, .55); }
.ds-live-dot { width: 7px; height: 7px; border-radius: 50%; background: #34D399; animation: ds-live 1.9s ease-out infinite; }
@keyframes ds-live { 0% { box-shadow: 0 0 0 0 rgba(52, 211, 153, .55); } 70% { box-shadow: 0 0 0 7px rgba(52, 211, 153, 0); } 100% { box-shadow: 0 0 0 0 rgba(52, 211, 153, 0); } }

/* Compact CTA inside the dark top bar (shown on wide desktop where the white-bar
   CTA is hidden so the full menu fits) */
.ds-tb-cta {
    display: inline-flex; align-items: center; gap: 6px; padding: 5px 13px; border-radius: 999px;
    font-weight: 700; font-size: 12px; color: #fff; background: var(--ds-grad-cta);
    box-shadow: 0 6px 16px -8px rgba(37, 99, 235, .7); transition: transform .18s var(--ds-ease), box-shadow .18s var(--ds-ease);
}
.ds-tb-cta:hover { transform: translateY(-1px); color: #fff; box-shadow: 0 10px 22px -8px rgba(37, 99, 235, .9); }

@media (prefers-reduced-motion: reduce) {
    .ds-btn-primary:hover::after { animation: none; }
    .ds-live-dot { animation: none; }
}

/* ==========================================================================
   14. NAVBAR REFINEMENT (v3.2) — clean SaaS pills, prominent Login/Register,
   no search in the bar, minimal top utility strip. Appended last → wins.
   ========================================================================== */

/* Slim, premium top utility strip */
.ds-topbar { font-size: 13px; }
.ds-topbar .ds-tb-tag { color: var(--ds-muted-2); font-weight: 500; letter-spacing: .01em; }

/* --- Nav links: clearly visible, soft pill hover, elegant active --- */
.ds-nav-link {
    color: #475569;                 /* slate-600 — readable on white */
    padding: 9px 14px; font-size: 14px; font-weight: 600; gap: 5px;
    box-shadow: none;
}
.ds-nav-link .material-symbols-rounded { color: #94A3B8; transition: color .18s var(--ds-ease), transform .25s var(--ds-ease); }
.ds-nav-link:hover { color: #0F172A; background: #F1F5F9; box-shadow: none; }
.ds-nav-link:hover .material-symbols-rounded { color: #64748B; }

/* Active = soft tinted pill (not a heavy saturated block) */
.ds-nav-link.ds-active {
    color: #1D4ED8; background: #EEF4FF; font-weight: 700;
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, .14);
}
.ds-nav-link.ds-active:hover { color: #1D4ED8; background: #E6EEFF; }
.ds-nav-link.ds-active .material-symbols-rounded { color: #3B82F6; }

/* Open dropdown trigger reads as engaged */
.ds-nav-open { color: #0F172A !important; background: #F1F5F9 !important; }
.ds-nav-open .material-symbols-rounded { color: #2563EB !important; }

.ds-nav-link:focus-visible { outline: 2px solid var(--ds-blue-bright); outline-offset: 2px; }
@media (min-width: 1536px) { .ds-nav-link { padding: 9px 16px; } }

/* --- Login / Register: visible, modern, well-spaced --- */
.ds-auth { display: inline-flex; align-items: center; gap: 10px; }
.ds-btn-login {
    display: inline-flex; align-items: center; gap: 7px; height: 42px; padding: 0 18px; border-radius: 11px;
    font-weight: 700; font-size: 14px; color: #1E293B; background: #fff; border: 1px solid var(--ds-nav-line);
    transition: color .18s, background .18s, border-color .18s, box-shadow .18s, transform .18s;
}
.ds-btn-login:hover { color: var(--ds-blue); border-color: #BFD3F5; background: var(--ds-nav-hover-bg); transform: translateY(-1px); }
.ds-btn-login:focus-visible { outline: 2px solid var(--ds-blue-bright); outline-offset: 2px; }
.ds-btn-register {
    display: inline-flex; align-items: center; gap: 7px; height: 42px; padding: 0 20px; border-radius: 11px;
    font-weight: 700; font-size: 14px; color: #fff; background: var(--ds-grad-cta); background-size: 160% 160%;
    box-shadow: var(--ds-shadow-cta); position: relative; overflow: hidden;
    transition: transform .18s, box-shadow .25s, background-position .35s;
}
.ds-btn-register:hover { color: #fff; transform: translateY(-1px); background-position: 100% 50%; box-shadow: 0 16px 36px -12px rgba(37, 99, 235, .8); }
.ds-btn-register::after {
    content: ""; position: absolute; top: 0; bottom: 0; left: -65%; width: 42%; pointer-events: none;
    background: linear-gradient(100deg, transparent, rgba(255, 255, 255, .5), transparent); transform: skewX(-18deg);
}
.ds-btn-register:hover::after { animation: ds-sheen .9s var(--ds-ease); }
.ds-btn-register:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }

@media (prefers-reduced-motion: reduce) { .ds-btn-register:hover::after { animation: none; } }

/* ==========================================================================
   15. NAVBAR BUTTONS — premium "glass pill" redesign (v3.3)
   --------------------------------------------------------------------------
   Elevates the top-level nav links + Login / Register CTAs and (importantly)
   resets the native <button> chrome that leaked through on the dropdown
   triggers (Certifications / Courses / Resources): because preflight is OFF,
   those <button>s rendered with the UA grey box + border, so they looked
   different from the plain <a> links (Home / Trainers / Jobs / LMS).
   Pure CSS on existing .ds-* classes → applies identically to navbar.html,
   navbar.blade.php and ds-ui-demo.html with NO markup change. Appended last
   so it wins the cascade.
   ========================================================================== */

/* Reset native button chrome so <button> triggers match the <a> links,
   then give every item a soft rounded-card footprint. */
.ds-nav-link {
    position: relative;
    -webkit-appearance: none; appearance: none;
    background: transparent; border: 0;
    color: #475569; font-weight: 600;
    border-radius: 12px;
    transition: color .2s var(--ds-ease), background .2s var(--ds-ease),
                box-shadow .22s var(--ds-ease), transform .2s var(--ds-ease);
}
.ds-nav-link .material-symbols-rounded {
    color: #94A3B8;
    transition: color .2s var(--ds-ease), transform .25s var(--ds-ease);
}

/* Animated gradient indicator that grows in from the centre */
.ds-nav-link::after {
    content: ""; position: absolute; left: 50%; bottom: 5px;
    width: 0; height: 2px; transform: translateX(-50%);
    border-radius: 999px; background: var(--ds-grad-cta);
    box-shadow: 0 0 6px rgba(37, 99, 235, .45);
    opacity: 0; pointer-events: none;
    transition: width .28s var(--ds-ease), opacity .2s var(--ds-ease);
}

/* Hover + open-dropdown trigger = frosted glass pill that lifts */
.ds-nav-link:hover,
.ds-nav-open {
    color: #0F172A !important;
    background: linear-gradient(180deg, #F6F9FF 0%, #ECF2FF 100%) !important;
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, .14),
                0 8px 18px -12px rgba(37, 99, 235, .55);
    transform: translateY(-1px);
}
.ds-nav-link:hover .material-symbols-rounded,
.ds-nav-open .material-symbols-rounded { color: var(--ds-blue) !important; }
.ds-nav-link:hover::after,
.ds-nav-open::after { width: 26px; opacity: 1; }

/* Active item = persistent tinted pill + indicator */
.ds-nav-link.ds-active {
    color: #1D4ED8; font-weight: 700;
    background: linear-gradient(180deg, #EEF4FF 0%, #E1EBFF 100%);
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, .18);
}
.ds-nav-link.ds-active::after { width: 26px; opacity: 1; }
.ds-nav-link.ds-active .material-symbols-rounded { color: var(--ds-blue); }
.ds-nav-link.ds-active:hover {
    color: #1D4ED8 !important;
    background: linear-gradient(180deg, #E8F0FF 0%, #D7E5FF 100%) !important;
    transform: translateY(-1px);
}

/* --- Login: refined glass-outline button --- */
.ds-btn-login {
    color: #1E293B;
    background: linear-gradient(180deg, #FFFFFF, #F7FAFF);
    border: 1px solid var(--ds-nav-line);
    box-shadow: 0 1px 2px rgba(2, 6, 23, .05), inset 0 1px 0 rgba(255, 255, 255, .7);
    transition: color .2s, background .25s, border-color .2s, box-shadow .25s, transform .2s var(--ds-ease);
}
.ds-btn-login .material-symbols-rounded { transition: transform .25s var(--ds-ease); }
.ds-btn-login:hover {
    color: var(--ds-blue); border-color: #BBD2F8;
    background: linear-gradient(180deg, #FFFFFF, #EEF4FF);
    box-shadow: 0 12px 24px -14px rgba(37, 99, 235, .55), inset 0 1px 0 rgba(255, 255, 255, .85);
    transform: translateY(-1px);
}
.ds-btn-login:hover .material-symbols-rounded { transform: translateX(-2px); }

/* --- Register: vivid gradient CTA — glow ring + sheen + sliding arrow --- */
.ds-btn-register {
    color: #fff;
    background: var(--ds-grad-cta); background-size: 180% 180%; background-position: 0% 50%;
    box-shadow: 0 12px 28px -12px rgba(37, 99, 235, .7), inset 0 1px 0 rgba(255, 255, 255, .3);
    transition: transform .2s var(--ds-ease), box-shadow .28s var(--ds-ease), background-position .55s var(--ds-ease);
}
.ds-btn-register .material-symbols-rounded { transition: transform .25s var(--ds-ease); }
.ds-btn-register:hover {
    color: #fff; transform: translateY(-2px); background-position: 100% 50%;
    box-shadow: 0 20px 40px -14px rgba(37, 99, 235, .85),
                0 0 0 1px rgba(59, 130, 246, .35),
                inset 0 1px 0 rgba(255, 255, 255, .38);
}
.ds-btn-register:hover .material-symbols-rounded { transform: translateX(3px); }

@media (prefers-reduced-motion: reduce) {
    .ds-nav-link, .ds-nav-link::after,
    .ds-btn-login, .ds-btn-login .material-symbols-rounded,
    .ds-btn-register, .ds-btn-register .material-symbols-rounded { transition: none; }
    .ds-nav-link:hover, .ds-nav-open,
    .ds-nav-link.ds-active:hover,
    .ds-btn-login:hover, .ds-btn-register:hover { transform: none; }
}

/* Specificity guard ----------------------------------------------------------
   The base reset `#ds-navbar a { color: inherit }` (§2) is ID-level (spec 101)
   so it beats every class-level `.ds-nav-link` / `.ds-btn-*` colour rule (20).
   For the <a>-based items — Home, Trainers, Jobs, LMS and the Login / Register
   CTAs — that left them inheriting the dark-theme `--ds-text` (#E6EDF7) and
   rendering near-invisible on the white bar (the faint links in the original
   screenshot). The <button> triggers were unaffected (a-selector doesn't match
   them), which is why only some items looked right. Re-assert the intended
   colours at ID level so every nav item is consistently readable.
   ----------------------------------------------------------------------------- */
#ds-navbar .ds-nav-link { color: #475569; }
#ds-navbar .ds-nav-link:hover,
#ds-navbar .ds-nav-open { color: #0F172A; }
#ds-navbar .ds-nav-link.ds-active { color: #1D4ED8; }
#ds-navbar .ds-btn-login { color: #1E293B; }
#ds-navbar .ds-btn-login:hover { color: var(--ds-blue); }
#ds-navbar .ds-btn-register,
#ds-navbar .ds-btn-register:hover { color: #fff; }

/* ==========================================================================
   16. NAVBAR STRUCTURE (v3.4) — per 03-navbar-requirements.md
   Brand-logo plate · dense 12-item primary menu · Login/Register dropdowns.
   ========================================================================== */

/* --- Brand: colored DevOpsSchool logo sitting transparent on the white bar
   (no plate). Uses the light-background colored logo (logo.png) — the supplied
   -w- file is the WHITE variant whose "School"/tagline vanish on white. --- */
.ds-brand-plate {
    display: inline-flex; align-items: center;
    background: transparent;
    transition: transform .25s var(--ds-ease);
}
.group:hover .ds-brand-plate { transform: translateY(-1px); }
.ds-brand-plate img { height: 60px; width: auto; display: block; }
.ds-brand-fallback { color: var(--ds-nav-strong); font-weight: 800; font-size: 22px; letter-spacing: -.01em; white-space: nowrap; }

/* --- Dense primary menu (12 items): compact pills, roomier from 2xl --- */
#ds-navbar nav .ds-nav-link { padding: 8px 8px; font-size: 13.5px; }
@media (min-width: 1536px) { #ds-navbar nav .ds-nav-link { padding: 9px 13px; font-size: 14px; } }

/* --- Login / Register dropdown triggers: rotating chevron (caret) + engaged
   state when open. The auth buttons are dropdowns now, so the caret should
   ROTATE rather than slide (override the v3.3 icon-slide just for the caret). --- */
.ds-auth-caret { transition: transform .25s var(--ds-ease), color .2s var(--ds-ease); }
.ds-btn-login:hover .ds-auth-caret,
.ds-btn-register:hover .ds-auth-caret { transform: none; }
.ds-btn-login.ds-auth-open .ds-auth-caret,
.ds-btn-register.ds-auth-open .ds-auth-caret { transform: rotate(180deg); }
.ds-btn-login.ds-auth-open {
    color: var(--ds-blue); border-color: #BBD2F8;
    background: linear-gradient(180deg, #FFFFFF, #EEF4FF);
}
.ds-btn-register.ds-auth-open { background-position: 100% 50%; }

/* --- Auth dropdown menu (reuses the .ds-pop card) --- */
.ds-auth-pop { padding: 8px; }
#ds-navbar .ds-auth-item {
    display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 10px;
    font-size: 13.5px; font-weight: 600; color: var(--ds-nav-text);
    transition: background .15s var(--ds-ease), color .15s var(--ds-ease), transform .15s var(--ds-ease);
}
#ds-navbar .ds-auth-item:hover { background: var(--ds-nav-hover-bg); color: var(--ds-blue); transform: translateX(2px); }
#ds-navbar .ds-auth-item .material-symbols-rounded { color: #94A3B8; font-size: 18px; transition: color .15s var(--ds-ease); }
#ds-navbar .ds-auth-item:hover .material-symbols-rounded { color: var(--ds-blue); }

/* ==========================================================================
   17. FOOTER REDESIGN (v3.5) — pill resources + clean 4-column links +
   contact/social bottom bar. Fixes the invisible accordion headers too.
   ========================================================================== */

/* Fix: the accordion header is a <button>; with preflight OFF it rendered with
   the native grey box, hiding the white .ds-foot-h heading. Reset its chrome. */
.ds-acc-btn {
    -webkit-appearance: none; appearance: none;
    background: transparent; border: 0; padding: 0;
    color: inherit; font: inherit; cursor: pointer;
}

/* Lead heading (Learning Resources): icon + label, drop the ::before dash */
.ds-foot-h-lead::before { display: none; }
#ds-footer .ds-foot-h-lead { gap: 10px; }
#ds-footer .ds-foot-h-lead .material-symbols-rounded { color: var(--ds-sky); font-size: 20px; }

/* Resource + contact pills (scoped colour beats the #ds-footer a {inherit} reset) */
#ds-footer .ds-foot-pill {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 8px 16px; border-radius: 999px;
    font-size: 13px; font-weight: 600; color: var(--ds-text-2);
    background: rgba(148, 163, 184, .08); border: 1px solid var(--ds-line);
    transition: color .18s var(--ds-ease), background .18s var(--ds-ease), border-color .18s var(--ds-ease), transform .18s var(--ds-ease);
}
#ds-footer .ds-foot-pill:hover {
    color: #fff; background: rgba(59, 130, 246, .16); border-color: rgba(59, 130, 246, .4); transform: translateY(-1px);
}
#ds-footer .ds-foot-pill .material-symbols-rounded { color: var(--ds-sky); font-size: 18px; }

/* Clean column links (no bullet dots) — readable, brighten on hover */
#ds-footer .ds-foot-link { color: var(--ds-text-2); }
#ds-footer .ds-foot-link:hover { color: #fff; }

/* Social circle buttons (bottom bar) */
#ds-footer .ds-foot-soc {
    display: inline-flex; align-items: center; justify-content: center;
    width: 38px; height: 38px; border-radius: 999px; color: var(--ds-text-2);
    background: rgba(148, 163, 184, .1); border: 1px solid var(--ds-line);
    transition: color .18s var(--ds-ease), background .18s var(--ds-ease), border-color .18s var(--ds-ease), transform .18s var(--ds-ease);
}
#ds-footer .ds-foot-soc:hover { color: #fff; background: var(--ds-grad-cta); border-color: transparent; transform: translateY(-2px); }

/* ==========================================================================
   18. MOBILE DRAWER LINK VISIBILITY (v3.6)
   The §2 base reset `#ds-navbar a { color: inherit }` is ID-level (spec 101),
   so the <a>-based drawer links inherited the HOST page's text colour (light on
   the dark demo/page) and rendered near-invisible on the white drawer. Re-assert
   the colour at ID level and strip the native <button> chrome on the Login /
   Register accordion toggles (preflight is off).
   ========================================================================== */
#ds-navbar .ds-drawer-link {
    -webkit-appearance: none; appearance: none;
    background: transparent; border: 0;
    color: var(--ds-nav-text);
}
#ds-navbar .ds-drawer-link:hover,
#ds-navbar .ds-drawer-link.ds-active {
    color: var(--ds-blue); background: var(--ds-nav-hover-bg);
}
#ds-navbar .ds-drawer-sub a { color: #64748B; }
#ds-navbar .ds-drawer-sub a:hover { color: var(--ds-blue); }

/* ==========================================================================
   19. NAVBAR IDENTITY (v3.7) — logged-in user pill + account menu.
   Driven client-side by `window.dsUser` (set per page). When it's absent the
   Login/Register dropdowns show; when present, this user menu shows instead.
   ========================================================================== */
#ds-navbar .ds-btn-user {
    display: inline-flex; align-items: center; gap: 8px; height: 42px;
    padding: 0 14px 0 12px; border-radius: 11px; font-weight: 700; font-size: 14px;
    color: #1E293B; background: linear-gradient(180deg, #FFFFFF, #F7FAFF);
    border: 1px solid var(--ds-nav-line);
    box-shadow: 0 1px 2px rgba(2, 6, 23, .05), inset 0 1px 0 rgba(255, 255, 255, .7);
    cursor: pointer; max-width: 230px;
    transition: color .2s, background .25s, border-color .2s, box-shadow .25s, transform .2s var(--ds-ease);
}
#ds-navbar .ds-btn-user:hover,
#ds-navbar .ds-btn-user.ds-auth-open {
    color: var(--ds-blue); border-color: #BBD2F8; background: linear-gradient(180deg, #FFFFFF, #EEF4FF);
    box-shadow: 0 12px 24px -14px rgba(37, 99, 235, .55), inset 0 1px 0 rgba(255, 255, 255, .85);
    transform: translateY(-1px);
}
#ds-navbar .ds-btn-user .material-symbols-rounded { color: #94A3B8; transition: color .2s var(--ds-ease); }
#ds-navbar .ds-btn-user:hover .material-symbols-rounded,
#ds-navbar .ds-btn-user.ds-auth-open .material-symbols-rounded { color: var(--ds-blue); }
#ds-navbar .ds-btn-user:hover .ds-auth-caret { transform: none; }
#ds-navbar .ds-btn-user.ds-auth-open .ds-auth-caret { transform: rotate(180deg); }
#ds-navbar .ds-user-name { max-width: 150px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* account dropdown header (name + email) */
#ds-navbar .ds-user-head {
    display: flex; flex-direction: column; gap: 2px;
    padding: 10px 16px; margin-bottom: 4px; border-bottom: 1px solid var(--ds-nav-line);
}
#ds-navbar .ds-user-head-name { font-size: 13.5px; font-weight: 700; color: var(--ds-nav-strong); }
#ds-navbar .ds-user-head-email { font-size: 12px; color: #64748B; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* logout item — red accent */
#ds-navbar .ds-auth-item.ds-auth-logout:hover { color: #DC2626; background: #FEF2F2; }
#ds-navbar .ds-auth-item.ds-auth-logout:hover .material-symbols-rounded { color: #DC2626; }

/* mobile drawer: signed-in header + logout */
#ds-navbar .ds-drawer-user { padding: 10px 16px 6px; }
#ds-navbar .ds-drawer-user-label { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: #94A3B8; }
#ds-navbar .ds-drawer-user-name { font-size: 16px; font-weight: 700; color: var(--ds-nav-strong); margin-top: 3px; }
#ds-navbar .ds-drawer-user-email { font-size: 12.5px; color: #64748B; margin-top: 2px; word-break: break-all; }
#ds-navbar .ds-drawer-link.ds-drawer-logout { color: #DC2626; }
#ds-navbar .ds-drawer-link.ds-drawer-logout:hover { color: #DC2626; background: #FEF2F2; }

/* ==========================================================================
   20. WORLD-CLASS AUTH BUTTONS (v3.8) — Sign in / Sign up as premium full pills,
   + hamburger is mobile/tablet only (hidden on desktop ≥xl).
   ========================================================================== */
#ds-navbar .ds-btn-login,
#ds-navbar .ds-btn-register,
#ds-navbar .ds-btn-user {
    height: 44px; border-radius: 9999px; gap: 6px;
    font-weight: 700; font-size: 14px; letter-spacing: .01em;
}

/* Sign in — clean outline pill that lifts on hover */
#ds-navbar .ds-btn-login {
    color: var(--ds-nav-text); background: #fff; padding: 0 20px;
    border: 1px solid var(--ds-nav-line);
    box-shadow: 0 1px 2px rgba(2, 6, 23, .04);
}
#ds-navbar .ds-btn-login:hover,
#ds-navbar .ds-btn-login.ds-auth-open {
    color: var(--ds-blue); border-color: #BFD3F5; background: #F6F9FF;
    box-shadow: 0 8px 18px -10px rgba(37, 99, 235, .5); transform: translateY(-1px);
}

/* Sign up — vivid blue→indigo→cyan gradient pill with glow + lift (sheen kept from §14) */
#ds-navbar .ds-btn-register {
    color: #fff; padding: 0 22px; border: 0;
    background: linear-gradient(135deg, #2563EB 0%, #4F46E5 48%, #06B6D4 100%);
    background-size: 200% 200%; background-position: 0% 50%;
    box-shadow: 0 10px 26px -8px rgba(37, 99, 235, .6), inset 0 1px 0 rgba(255, 255, 255, .3);
}
#ds-navbar .ds-btn-register:hover,
#ds-navbar .ds-btn-register.ds-auth-open {
    color: #fff; transform: translateY(-2px); background-position: 100% 50%;
    box-shadow: 0 20px 42px -10px rgba(37, 99, 235, .8), 0 0 0 1px rgba(99, 102, 241, .45), inset 0 1px 0 rgba(255, 255, 255, .4);
}

/* Hamburger: shown on mobile/tablet, HIDDEN on desktop (overrides .ds-icon-btn's
   display:inline-flex, which was beating Tailwind's xl:hidden by source order). */
@media (min-width: 1280px) {
    #ds-navbar .ds-icon-btn { display: none !important; }
}

/* ==========================================================================
   21. Floating chat button — themed (brand blue) instead of WhatsApp green,
   so it matches the DevOpsSchool palette.
   ========================================================================== */
#ds-whatsapp {
    background: var(--ds-grad-cta);
    box-shadow: 0 14px 34px -10px rgba(37, 99, 235, .55), 0 4px 10px rgba(0, 0, 0, .2);
}
#ds-whatsapp:hover { box-shadow: 0 20px 44px -10px rgba(37, 99, 235, .75); }
#ds-whatsapp .ds-wa-ico::after { border-color: rgba(59, 130, 246, .85); }
