/* ═══════════════════════════════════════════
   AlmaMate — Global Stylesheet
   Shared across all pages: variables, nav, footer, utilities
   ═══════════════════════════════════════════ */

/* ── CSS Variables ── */
:root {
  --navy:      #0A2E5C;
  --blue:      #1565C0;
  --blue-mid:  #1E88E5;
  --blue-lt:   #E3F2FD;
  --yellow:    #FFB800;
  --yellow-lt: #FFF8E1;
  --cream:     #F8FAFF;
  --white:     #FFFFFF;
  --charcoal:  #0D1B2E;
  --txt:       #1E293B;
  --txt-mid:   #4A6080;
  --muted:     #64748B;
  --border:    rgba(21,101,192,0.12);
  --mist:      #EBF3FF;
}

/* ── Reset & Base ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',Arial,sans-serif;color:var(--txt);background:var(--white);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

/* ── Announcement Bar ── */
.announcement-bar{background:var(--navy);color:#fff;text-align:center;padding:.5rem 5%;font-size:.82rem;display:flex;align-items:center;justify-content:center;gap:.75rem;position:relative;z-index:200}
.announcement-bar a{color:var(--yellow);font-weight:600;text-decoration:none}
.announcement-bar button{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;font-size:1rem;padding:.2rem;position:absolute;right:1rem;line-height:1}

/* ── Navigation ── */
#main-nav{position:sticky;top:0;z-index:100;background:rgba(248,250,255,0.96);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding:0 5%;height:72px;display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:box-shadow .25s}
#main-nav.scrolled{box-shadow:0 4px 24px rgba(10,46,92,0.08)}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none; height: 40px;
    width: auto;}
.nav-logo-mark{width:38px;height:38px;background:var(--yellow);color:var(--navy);border-radius:9px;display:grid;place-items:center;font-weight:900;font-size:.85rem;flex-shrink:0}
.nav-logo-text{font-weight:800;font-size:1.05rem;color:var(--navy)}
.nav-logo-text span{font-weight:400;opacity:.7}
.nav-logo img{
    height: 100% !important;
    width: auto;
}
.nav-links{display:flex;list-style:none;align-items:center;gap:2px;margin:0;padding:0}
.nav-links a{padding:.45rem .85rem;border-radius:8px;font-size:.85rem;font-weight:500;color:var(--navy);text-decoration:none;transition:background .18s}
.nav-links a:hover,.nav-links a.active{background:rgba(21,101,192,.08)}
.nav-cta{background:var(--navy);color:#fff!important;border-radius:9px;padding:.5rem 1.2rem;font-weight:600;font-size:.85rem;text-decoration:none;transition:background .18s}
.nav-cta:hover{background:var(--blue)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:all .2s}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav-mobile-menu {
    display: none;
    position: fixed;
    top: 72px; /* Matches your nav height */
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    z-index: 9999; /* Higher than #main-nav */
    overflow-y: auto;
    padding: 1.5rem 5%;
}

/* Add !important to ensure display:none is overridden */
.nav-mobile-menu.open {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}
.nav-mobile-menu ul{list-style:none;padding:0;margin:0}
.nav-mobile-menu ul li{border-bottom:1px solid var(--border)}
.nav-mobile-menu ul li a{display:block;padding:1rem 0;font-size:1rem;font-weight:500;color:var(--navy);text-decoration:none}
.mobile-cta{display:block;margin-top:1.25rem;background:var(--navy);color:#fff;text-align:center;padding:.875rem;border-radius:10px;font-weight:700;text-decoration:none;font-size:1rem}

/* ── Footer ── */
footer{background:#071E3D;color:rgba(255,255,255,.65);padding:4rem 5% 2rem}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-mark{width:38px;height:38px;background:var(--yellow);color:var(--navy);border-radius:9px;display:grid;place-items:center;font-weight:900;font-size:.85rem;flex-shrink:0}
.footer-brand{display:flex;align-items:center;gap:.625rem;margin-bottom:1rem}
.footer-name{color:#fff;font-weight:800;font-size:1.05rem}
.footer-desc{font-size:.8rem;line-height:1.75;margin-bottom:1.25rem;max-width:28ch}
.footer-offices{font-size:.75rem;line-height:1.9;color:rgba(255,255,255,.45)}
footer h4{color:#fff;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.875rem}
footer ul{list-style:none;padding:0;margin:0}
footer li{margin-bottom:.4rem}
footer a{font-size:.8rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color .18s}
footer a:hover{color:var(--yellow)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.74rem;color:rgba(255,255,255,.3)}
.footer-bottom a{color:rgba(255,255,255,.4);text-decoration:none}
.footer-bottom a:hover{color:var(--yellow)}

/* ── Flash / Alert messages ── */
.flash-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0;padding:14px 18px;border-radius:10px;margin-bottom:1.5rem;font-size:.9rem}
.flash-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;padding:14px 18px;border-radius:10px;margin-bottom:1.5rem;font-size:.9rem}

/* ── Common Buttons ── */
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:var(--navy);color:#fff;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;font-size:.9rem;text-decoration:none;border:none;cursor:pointer;transition:background .18s}
.btn-primary:hover{background:var(--blue)}
.btn-yellow{display:inline-flex;align-items:center;gap:.5rem;background:var(--yellow);color:var(--navy);padding:.75rem 1.5rem;border-radius:10px;font-weight:700;font-size:.9rem;text-decoration:none;border:none;cursor:pointer;transition:opacity .18s}
.btn-yellow:hover{opacity:.9}
.btn-ghost-white{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.12);color:#fff;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;font-size:.9rem;text-decoration:none;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:background .18s}
.btn-ghost-white:hover{background:rgba(255,255,255,.2)}

/* ── Utilities ── */
.section-label{font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);display:block;margin-bottom:.625rem}
.container{max-width:1200px;margin:0 auto;padding:0 5%}

/* ── Blog card (used on blog listing page) ── */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:2rem}
.blog-card{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(10,46,92,.1)}
.blog-card-img{height:200px;background:var(--mist);overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover}
.blog-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.blog-card-cat{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);margin-bottom:.5rem}
.blog-card-title{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:.5rem;line-height:1.4}
.blog-card-excerpt{font-size:.83rem;color:var(--muted);line-height:1.6;flex:1}
.blog-card-meta{font-size:.75rem;color:var(--muted);margin-top:1rem;display:flex;gap:.75rem}

/* ── Responsive ── */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .nav-hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
}
