@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Playfair+Display:wght@600;700&display=swap');

:root { --ink:#172337; --navy:#0d2037; --gold:#b48a4d; --paper:#faf8f3; --muted:#647083; --line:#e6e2d8; --white:#fff; }
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; color:var(--ink); background:var(--paper); font:16px/1.65 'DM Sans',sans-serif; }
a { color:inherit; text-decoration:none; }
.container { width:min(1160px, calc(100% - 40px)); margin:auto; }
.topbar { background:var(--navy); color:#e9edf2; font-size:.84rem; }
.topbar .container { min-height:38px; display:flex; align-items:center; justify-content:space-between; gap:15px; }
.topbar a { color:#fff; }
.site-header { position:sticky; top:0; z-index:20; background:#fff; border-bottom:1px solid var(--line); }
.nav-wrap { min-height:82px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand { position:relative; display:flex; align-items:center; min-width:330px; height:100px; font-family:'Playfair Display',serif; font-size:1.22rem; font-weight:700; line-height:1.05; color:var(--navy); }
.brand-mark { width:42px; height:42px; display:grid; place-items:center; border:1px solid var(--gold); color:var(--gold); font-size:1.1rem; }
.brand small { display:block; margin-top:4px; color:var(--gold); font:600 .57rem/1.1 'DM Sans',sans-serif; letter-spacing:.09em; text-transform:uppercase; }
.nav { display:flex; align-items:center; gap:3px; }
.nav a { padding:10px 9px; font-size:.77rem; font-weight:700; text-transform:uppercase; letter-spacing:.025em; color:#39465a; }
.nav a:hover,.nav a.active { color:var(--gold); }
.menu-button { display:none; border:0; background:none; color:var(--navy); font:700 1.3rem 'DM Sans'; }
.button { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:13px 22px; background:var(--gold); color:#fff; font-size:.8rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; transition:.2s; }
.button:hover { background:#94703b; color:#fff; }
.button.outline { background:transparent; border:1px solid rgba(255,255,255,.6); }
.button.outline:hover { background:#fff; color:var(--navy); }
.hero { min-height:610px; color:#fff; display:grid; place-items:center; background:linear-gradient(105deg,rgba(9,26,47,.98),rgba(16,41,69,.86)),radial-gradient(circle at 85% 30%,rgba(180,138,77,.28),transparent 28%); }
.hero-content { max-width:790px; padding:82px 0; }
.eyebrow { display:block; margin-bottom:18px; color:var(--gold); font-size:.78rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; }
.hero h1,.page-hero h1 { margin:0 0 20px; font:700 clamp(2.7rem,6vw,5.25rem)/1.06 'Playfair Display',serif; }
.hero p { max-width:650px; margin:0 0 30px; color:#dce4ed; font-size:1.1rem; }
.actions { display:flex; flex-wrap:wrap; gap:12px; }
.section { padding:88px 0; }
.section.alt { background:#fff; }
.section-heading { max-width:700px; margin-bottom:40px; }
.section-heading h2,.split h2 { margin:0; color:var(--navy); font:700 clamp(2rem,4vw,3.35rem)/1.15 'Playfair Display',serif; }
.section-heading p { color:var(--muted); }
.split { display:grid; grid-template-columns:1fr 1.05fr; align-items:center; gap:68px; }
.placeholder { min-height:385px; padding:28px; display:flex; align-items:end; border:1px dashed #ad9d81; color:#866837; background:linear-gradient(135deg,#e9e1d2,#f8f5ef); font-size:.75rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; }
.image-frame { display:block; position:relative; overflow:hidden; background:#e9e1d2; }
.image-frame img { width:100%; height:100%; display:block; object-fit:cover; }
.about-image { height:430px; }
.banking-image { min-height:320px; }
.brand img { display:none; }
.brand::after { content:''; display:block; width:110px; height:92px; background:url('../img/logo.png') center / contain no-repeat; }
.brand::before { display:none; }
.brand-copy { position:absolute; left:122px; top:26px; white-space:nowrap; }
.brand-copy strong { display:block; color:var(--navy); font:700 1.48rem/1 'Playfair Display',serif; }
.brand-copy small { display:block; margin-top:5px; color:var(--gold); font:600 .58rem/1 'DM Sans',sans-serif; letter-spacing:.1em; text-transform:uppercase; }
.footer-grid > div:first-child img { display:none; }
.footer-grid > div:first-child::before { content:''; display:block; width:230px; height:125px; margin-bottom:12px; background:url('../img/logo_full_with_name.png') left center / contain no-repeat; }
.team-summary .image-frame { height:280px; }
.team-summary .image-frame img { object-fit:contain; object-position:center; }
.team-summary .card { padding:0; overflow:hidden; }
.team-summary .card-copy { padding:21px; }
.team-summary .card h3 { margin-top:0; }
.person .portrait { height:430px; }
.person .portrait img { object-fit:contain; object-position:center; }
.interns { width:min(1160px, calc(100% - 40px)); margin:55px auto 0; }
.intern-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:24px; max-width:none; }
.intern { display:grid; grid-template-columns:170px minmax(0,1fr); gap:24px; align-items:start; min-height:270px; padding:24px; background:#fff; border:1px solid var(--line); }
.intern .image-frame { height:220px; }
.intern .image-frame img { object-fit:contain; object-position:center; }
.contact > * { min-width:0; }
.thumb { object-position:top center; }
.service-list { padding:0; margin:0; list-style:none; columns:2; color:var(--muted); }
.service-list li { margin:0 0 9px; break-inside:avoid; }
.service-list li::before { content:'✦'; color:var(--gold); margin-right:8px; }
.float-contact { position:fixed; z-index:30; right:22px; bottom:22px; display:grid; gap:10px; }
.float-contact a { width:51px; height:51px; display:grid; place-items:center; border-radius:50%; color:#fff; box-shadow:0 8px 20px rgba(9,24,42,.24); font-weight:700; font-size:1.2rem; }
.float-contact .call { background:var(--navy) url('../img/phone.png') center / 56% no-repeat; color:transparent; font-size:0; }
.float-contact .whatsapp { background:#25d366 url('../img/whatsapp.png') center / 60% no-repeat; color:transparent; font-size:0; }
.prose p { color:var(--muted); }
.ticks { padding:0; margin:26px 0 0; list-style:none; display:grid; grid-template-columns:repeat(2,1fr); gap:11px 25px; color:#334054; font-weight:600; }
.ticks li::before { content:'✦'; margin-right:9px; color:var(--gold); }
.stats { display:grid; grid-template-columns:repeat(3,1fr); margin-top:-1px; border-top:1px solid rgba(255,255,255,.12); }
.stat { padding:26px 36px; border-right:1px solid rgba(255,255,255,.12); background:var(--navy); color:#fff; }
.stat strong { display:block; color:var(--gold); font:700 2rem 'Playfair Display'; }
.stat span { font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; }
.cards { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.card { padding:29px; background:#fff; border:1px solid var(--line); }
.card .number { color:var(--gold); font:700 1.35rem 'Playfair Display'; }
.card h3 { margin:13px 0 10px; color:var(--navy); font:700 1.35rem 'Playfair Display'; }
.card p { margin:0; color:var(--muted); font-size:.94rem; }
.testimonials { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:20px; }
.testimonial { position:relative; padding:32px 32px 27px; background:#fff; border:1px solid var(--line); }
.testimonial::before { content:'“'; display:block; height:31px; color:var(--gold); font:700 3.6rem/.8 'Playfair Display',serif; }
.testimonial blockquote { margin:15px 0 22px; color:#46536a; font-size:.95rem; }
.testimonial cite { display:block; color:var(--navy); font:700 1rem 'Playfair Display',serif; font-style:normal; }
.testimonial small { display:block; margin-top:3px; color:var(--gold); font:700 .7rem 'DM Sans',sans-serif; letter-spacing:.08em; text-transform:uppercase; }
.feature-band { padding:70px 0; background:var(--navy); color:#fff; }
.feature-band .split { align-items:start; }
.feature-band h2 { color:#fff; }
.feature-band p { color:#d0d9e4; }
.list { padding:0; margin:20px 0 0; list-style:none; columns:2; }
.list li { margin:0 0 10px; break-inside:avoid; }
.list li::before { content:'—'; margin-right:8px; color:var(--gold); }
.page-hero { padding:96px 0 85px; color:#fff; background:linear-gradient(120deg,#0d2037,#1d3856); }
.page-hero h1 { font-size:clamp(2.5rem,5vw,4rem); }
.page-hero p { max-width:670px; margin:0; color:#d9e1ea; font-size:1.05rem; }
.practice-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.practice { padding:32px; border:1px solid var(--line); background:#fff; }
.practice h2 { margin:0 0 13px; color:var(--navy); font:700 1.6rem 'Playfair Display'; }
.practice ul { padding:0; margin:0; list-style:none; color:var(--muted); columns:2; font-size:.92rem; }
.practice li { margin:0 0 8px; break-inside:avoid; }
.practice li::before { content:'•'; color:var(--gold); margin-right:8px; }
.team { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.person { background:#fff; border:1px solid var(--line); }
.person .placeholder { min-height:230px; }
.person-copy { padding:26px; }
.person h2 { margin:0 0 5px; color:var(--navy); font:700 1.45rem 'Playfair Display'; }
.role { color:var(--gold); font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.09em; }
.person p { color:var(--muted); font-size:.92rem; }
.contact { display:grid; grid-template-columns:1.1fr .9fr; gap:54px; }
.contact-card { padding:32px; background:#fff; border-top:3px solid var(--gold); box-shadow:0 8px 30px rgba(13,32,55,.06); }
.contact-card h2 { color:var(--navy); font:700 1.65rem 'Playfair Display'; }
.contact-card address { color:var(--muted); font-style:normal; }
.contact-card dt { margin-top:20px; color:var(--navy); font-size:.76rem; letter-spacing:.1em; text-transform:uppercase; }
.contact-card dd { margin:4px 0; color:var(--muted); }
.cta { padding:67px 0; color:#fff; background:#b48a4d; }
.cta .container { display:flex; align-items:center; justify-content:space-between; gap:24px; }
.cta h2 { margin:0; font:700 clamp(1.8rem,3vw,2.6rem)/1.15 'Playfair Display'; }
.footer { padding:48px 0 22px; background:#09182a; color:#b7c2d0; }
.footer-grid { display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:35px; }
.footer h3 { margin:0 0 12px; color:#fff; font:700 1.25rem 'Playfair Display'; }
.footer p,.footer a { font-size:.9rem; }
.footer-links { display:grid; gap:7px; }
.copyright { margin-top:35px; padding-top:20px; border-top:1px solid rgba(255,255,255,.1); font-size:.78rem; }
@media(max-width:1050px) { .nav a { padding:9px 6px; font-size:.69rem; } }
@media(max-width:850px) { .topbar .container { justify-content:center; } .topbar span { display:none; } .nav-wrap { min-height:92px; } .menu-button { display:block; } .nav { display:none; position:absolute; top:92px; left:0; right:0; padding:13px 20px 20px; flex-direction:column; align-items:stretch; background:#fff; border-bottom:1px solid var(--line); } .nav.open { display:flex; } .nav a { padding:10px 0; } .split,.contact { grid-template-columns:1fr; gap:35px; } .cards,.team { grid-template-columns:repeat(2,1fr); } .placeholder { min-height:300px; } .intern-grid { grid-template-columns:1fr; } }
@media(max-width:580px) { .container { width:min(100% - 30px,1160px); } .topbar { font-size:.75rem; } .brand { min-width:245px; height:78px; } .brand::after { width:78px; height:70px; } .brand-copy { left:87px; top:24px; } .brand-copy strong { font-size:1.08rem; } .brand-copy small { margin-top:4px; font-size:.43rem; } .footer-grid > div:first-child::before { width:220px; height:120px; } .hero { min-height:540px; } .section { padding:62px 0; } .stats,.cards,.team,.practice-grid,.footer-grid,.intern-grid,.testimonials { grid-template-columns:1fr; } .stat { border-bottom:1px solid rgba(255,255,255,.12); } .ticks,.list,.practice ul,.service-list { grid-template-columns:1fr; columns:1; } .cta .container { display:block; } .cta .button { margin-top:22px; } .team-summary .image-frame { height:320px; } .person .portrait { height:370px; } .interns { width:min(100% - 30px,1160px); } .intern { grid-template-columns:112px minmax(0,1fr); gap:16px; padding:18px; min-height:0; } .intern .image-frame { height:155px; } .float-contact { right:15px; bottom:15px; } }
