/* ============================================================
   marketing.css — Marketing Layout (nav, footer, shared utilities)
   Extracted from resources/views/marketing/layouts/app.blade.php
   ============================================================ */

:root {
    --bg:       #FFFFFF;
    --bg2:      #F3F7FC;
    --bg3:      #E6EEF8;
    --border:   #CBD5E8;
    --text:     #0C1B3A;
    --muted:    #5A6B8A;
    --accent:   #B8940C;
    --accent2:  #B91C1C;
    --blue:     #1D4ED8;
    --green:    #15803D;
    --nav-bg:   #0C1B3A;
    --nav-h:    68px;
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Poppins', sans-serif; background: var(--bg); color: var(--text); line-height: 1.6; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ── Navbar ── */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 999; height: var(--nav-h); display: flex; align-items: center; background: var(--nav-bg); border-bottom: 3px solid var(--accent); }
.nav-inner { max-width: 1220px; width: 100%; margin: 0 auto; padding: 0 1.5rem; display: flex; align-items: center; gap: 1.5rem; }
.nav-logo { display: flex; align-items: center; gap: .65rem; flex-shrink: 0; }
.nav-logo-icon { width: 36px; height: 36px; border-radius: 8px; background: var(--accent); display: flex; align-items: center; justify-content: center; font-size: .9rem; color: #fff; font-weight: 900; flex-shrink: 0; }
.nav-logo-text { color: #fff; font-size: 1rem; font-weight: 700; line-height: 1.15; }
.nav-logo-text small { display: block; font-size: .58rem; font-weight: 400; color: rgba(255,255,255,.5); letter-spacing: .04em; text-transform: uppercase; }
.nav-links { display: flex; align-items: center; gap: .1rem; margin-left: auto; list-style: none; }
.nav-links a { padding: .38rem .82rem; border-radius: 6px; font-size: .84rem; font-weight: 500; color: rgba(255,255,255,.7); transition: color .15s, background .15s; white-space: nowrap; }
.nav-links a:hover, .nav-links a.active { color: #fff; background: rgba(255,255,255,.1); }
.nav-ctas { display: flex; align-items: center; gap: .55rem; flex-shrink: 0; }
.btn-ghost { padding: .36rem .95rem; border-radius: 7px; font-size: .82rem; font-weight: 600; color: rgba(255,255,255,.85); border: 1.5px solid rgba(255,255,255,.25); transition: border-color .18s, color .18s; }
.btn-ghost:hover { border-color: rgba(255,255,255,.6); color: #fff; }
.btn-amber { padding: .38rem 1.1rem; border-radius: 7px; font-size: .82rem; font-weight: 700; background: var(--accent); color: #fff; transition: opacity .18s, transform .15s; }
.btn-amber:hover { opacity: .88; transform: translateY(-1px); }
.nav-toggle { display: none; background: none; border: none; cursor: pointer; color: #fff; font-size: 1.2rem; padding: .4rem; margin-left: auto; }

@media(max-width:900px) {
    .nav-links, .nav-ctas { display: none; position: fixed; top: var(--nav-h); left: 0; right: 0; background: var(--nav-bg); border-bottom: 1px solid rgba(255,255,255,.1); padding: 1rem 1.5rem 1.5rem; flex-direction: column; align-items: flex-start; gap: .35rem; }
    .nav-links.show, .nav-ctas.show { display: flex; }
    .nav-ctas.show { top: auto; position: static; border: none; padding: .75rem 0 0; flex-direction: row; }
    .nav-toggle { display: block; }
}

/* ── Institutional strip ── */
.inst-strip { background: var(--accent); padding: .4rem 1.5rem; text-align: center; font-size: .72rem; font-weight: 600; color: #fff; letter-spacing: .03em; }

/* ── Footer ── */
.footer { background: var(--nav-bg); color: rgba(255,255,255,.7); padding: 4rem 1.5rem 2rem; }
.footer-inner { max-width: 1220px; margin: 0 auto; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.6fr; gap: 3rem; margin-bottom: 3rem; }
.f-brand-name { font-size: 1rem; font-weight: 800; margin-bottom: .6rem; color: #fff; }
.f-brand-desc { font-size: .82rem; color: rgba(255,255,255,.45); line-height: 1.75; margin-bottom: 1.1rem; }
.f-socials { display: flex; gap: .5rem; }
.f-socials a { width: 34px; height: 34px; border-radius: 8px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); display: flex; align-items: center; justify-content: center; font-size: .8rem; color: rgba(255,255,255,.5); transition: background .18s, color .18s; }
.f-socials a:hover { background: var(--accent); color: #fff; }
.f-col h4 { font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-bottom: .9rem; }
.f-col ul { list-style: none; }
.f-col li { margin-bottom: .5rem; }
.f-col a { font-size: .82rem; color: rgba(255,255,255,.45); transition: color .18s; }
.f-col a:hover { color: rgba(255,255,255,.85); }
.f-contact-row { display: flex; align-items: flex-start; gap: .6rem; margin-bottom: .65rem; font-size: .82rem; color: rgba(255,255,255,.45); }
.f-contact-row i { color: var(--accent); margin-top: .2rem; width: 14px; flex-shrink: 0; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding-top: 1.5rem; display: flex; align-items: center; justify-content: space-between; font-size: .74rem; color: rgba(255,255,255,.3); flex-wrap: wrap; gap: .5rem; }
.footer-disclaimer { font-size: .72rem; color: rgba(255,255,255,.25); margin-top: .5rem; }
@media(max-width:900px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; } }
@media(max-width:560px) { .footer-grid { grid-template-columns: 1fr; } .footer-bottom { flex-direction: column; text-align: center; } }

/* ── Shared utilities ── */
.container { max-width: 1220px; margin: 0 auto; padding: 0 1.5rem; }
.section { padding: 5.5rem 0; }
.section-sm { padding: 4rem 0; }
.pill { display: inline-flex; align-items: center; gap: .4rem; background: rgba(184,148,12,.1); color: var(--accent); border: 1px solid rgba(184,148,12,.25); font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: .25rem .75rem; border-radius: 4px; margin-bottom: .9rem; }
.sec-title { font-size: clamp(1.6rem,3vw,2.2rem); font-weight: 800; line-height: 1.25; margin-bottom: .7rem; color: var(--text); }
.sec-sub { font-size: .92rem; color: var(--muted); max-width: 540px; line-height: 1.75; }
.t-center { text-align: center; }
.t-center .sec-sub { margin: 0 auto; }
.text-accent { color: var(--accent); }
.page-top { padding-top: var(--nav-h); }
input::placeholder, textarea::placeholder { color: rgba(91,107,138,.4); opacity: 1; }
