/* Alayande Inc. — Shared Styles */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0B1F3A;--navy-mid:#0e2a4a;--navy-dark:#071428;--navy-card:#0d1e33;
  --gold:#C9A227;--gold-light:#e0b840;
  --cream:#F5F2EC;--cream-dark:#ede9e0;
  --text-dark:#1a2a3a;--text-mid:#3a4a5a;
}
html{scroll-behavior:smooth}
body{font-family:'Source Serif 4',Georgia,serif;background:var(--cream);color:var(--text-dark);line-height:1.75;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none}
address{font-style:normal}

/* LOADING */
#loading-screen{position:fixed;inset:0;z-index:9999;background:var(--navy);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;transition:opacity .6s,visibility .6s}
#loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loading-logo-wrap{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center}
.loading-logo-wrap img{width:160px;height:auto;object-fit:contain;mix-blend-mode:lighten;position:relative;z-index:2}
.loading-ring{position:absolute;inset:0;border-radius:50%;border:2px solid transparent;border-top-color:var(--gold);animation:spin 1.2s linear infinite}
.loading-ring-2{inset:8px;border-top-color:transparent;border-right-color:var(--gold);opacity:.5;animation-duration:1.8s;animation-direction:reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-tagline{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.5)}
.loading-dots{display:flex;gap:6px}
.loading-dots span{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:bdot 1.2s ease-in-out infinite}
.loading-dots span:nth-child(2){animation-delay:.2s}
.loading-dots span:nth-child(3){animation-delay:.4s}
@keyframes bdot{0%,80%,100%{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}
.loading-bar-wrap{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.08)}
.loading-bar{height:100%;background:var(--gold);width:0%;animation:lbar 2s ease-out forwards}
@keyframes lbar{to{width:100%}}

/* TOP BAR */
.top-bar{background:var(--navy-dark);padding:7px 24px;display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:500;letter-spacing:1px;color:var(--gold)}
.top-bar a{color:var(--gold);display:inline-flex;align-items:center;gap:5px;transition:color .2s}
.top-bar a:hover{color:#fff}
.top-bar .sep{color:rgba(255,255,255,.2);margin:0 4px}
@media(max-width:640px){.top-bar{display:none}}

/* NAV */
#main-nav{position:sticky;top:0;z-index:100;background:var(--navy);transition:box-shadow .3s}
#main-nav.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.35)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:96px}
.nav-logo img{height:90px;width:auto;object-fit:contain;mix-blend-mode:lighten;transition:opacity .3s}
.nav-logo img:hover{opacity:.85}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{font-family:'Montserrat',sans-serif;font-size:11.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.8);position:relative;padding-bottom:4px;transition:color .25s}
.nav-dot{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--gold);margin-right:6px;opacity:0;transform:scale(0);transition:opacity .2s,transform .2s;vertical-align:middle;position:relative;top:-1px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--gold);transition:width .3s cubic-bezier(.4,0,.2,1)}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a:hover .nav-dot,.nav-links a.active .nav-dot{opacity:1;transform:scale(1)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:#facc15}
.nav-links a.active::after{background:#facc15}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px}
.hamburger span{display:block;width:24px;height:2px;background:white;border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{background:var(--navy-card);max-height:0;overflow:hidden;transition:max-height .35s,opacity .35s;opacity:0}
.mobile-menu.open{max-height:400px;opacity:1}
.mobile-menu ul{list-style:none;padding:8px 24px 20px}
.mobile-menu a{display:block;padding:12px 8px;font-family:'Montserrat',sans-serif;font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.8);border-bottom:1px solid rgba(255,255,255,.07);position:relative;transition:color .25s,padding-left .25s}
.mobile-menu a::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--gold);transition:width .25s}
.mobile-menu a:hover::before,.mobile-menu a.active::before{width:3px}
.mobile-menu a:hover,.mobile-menu a.active{color:#fff;padding-left:14px}
.mobile-menu a.active{color:#facc15}
.mobile-menu .mobile-phone{display:flex;align-items:center;gap:8px;padding:14px 8px 0;font-size:13px;color:var(--gold);border-bottom:none;letter-spacing:.5px}
.mobile-menu .mobile-phone:hover{color:#fff;padding-left:8px}
.mobile-menu .mobile-phone::before{display:none}
@media(max-width:768px){.nav-links{display:none}.hamburger{display:flex}}

/* HERO */
.hero{position:relative;min-height:85vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(7,20,40,.93) 0%,rgba(7,20,40,.76) 50%,rgba(7,20,40,.42) 100%)}
.hero-content{position:relative;z-index:1;max-width:1200px;margin:0 auto;width:100%;padding:100px 24px 80px}
.hero-inner{max-width:600px}
.hero-location{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;animation:fiu .7s ease both}
.hero-h1{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,6vw,4.5rem);font-weight:700;color:#fff;line-height:1.12;margin-bottom:24px;animation:fiu .7s .1s ease both}
.hero-h1 em{font-style:normal;color:var(--gold)}
.hero-rule{width:64px;height:2px;background:var(--gold);margin-bottom:24px;animation:fiu .7s .2s ease both}
.hero-desc{font-size:clamp(1rem,2vw,1.15rem);color:rgba(255,255,255,.82);max-width:500px;margin-bottom:36px;animation:fiu .7s .3s ease both}
.hero-btns{display:flex;flex-wrap:wrap;gap:14px;animation:fiu .7s .4s ease both}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);animation:bsc 2s infinite;color:rgba(201,162,39,.7)}
@keyframes bsc{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes fiu{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* BUTTONS */
.btn-gold{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:var(--gold);color:var(--navy-dark);font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;transition:background .25s,gap .25s}
.btn-gold:hover{background:var(--gold-light);gap:12px}
.btn-outline{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border:1px solid rgba(255,255,255,.4);color:#fff;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;transition:background .25s}
.btn-outline:hover{background:rgba(255,255,255,.1)}
.btn-navy{display:inline-flex;align-items:center;gap:8px;padding:15px 36px;background:var(--navy);color:var(--cream);font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;transition:background .25s,gap .25s}
.btn-navy:hover{background:var(--navy-mid);gap:14px}
.btn-text-link{display:inline-flex;align-items:center;gap:8px;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--navy);margin-top:24px;transition:gap .25s}
.btn-text-link:hover{gap:14px}
.btn-text-link-light{display:inline-flex;align-items:center;gap:8px;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-top:24px;transition:gap .25s}
.btn-text-link-light:hover{gap:14px}

/* SHARED SECTION ELEMENTS */
.section-label{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.section-rule{width:48px;height:1px;background:var(--gold);margin:16px 0 24px}
.section-rule-center{margin:16px auto 24px}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.fade-up{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* MISSION */
.mission-section{padding:88px 0;background:var(--cream)}
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:900px){.mission-grid{grid-template-columns:1fr;gap:40px}}
.mission-h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:8px}
.mission-h2 em{font-style:normal;color:var(--gold)}
.mission-p{font-size:1rem;color:var(--text-mid);line-height:1.85;margin-bottom:16px}
.mission-img-wrap{position:relative}
.mission-img-wrap::before{content:'';position:absolute;top:-16px;left:-16px;right:16px;bottom:16px;border:1px solid rgba(201,162,39,.3);pointer-events:none}
.mission-img-wrap img{position:relative;width:100%;height:380px;object-fit:cover}
@media(max-width:640px){.mission-img-wrap img{height:260px}}

/* SUBSIDIARIES CARDS */
.subs-section{padding:88px 0;background:var(--navy)}
.subs-header{text-align:center;margin-bottom:56px}
.subs-h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;color:#fff;margin-bottom:8px}
.subs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.subs-grid{grid-template-columns:1fr}}
@media(min-width:640px) and (max-width:900px){.subs-grid{grid-template-columns:1fr 1fr}}
.sub-card{background:var(--navy-card);padding:32px;border-left:3px solid var(--gold);transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s}
.sub-card:hover{transform:translateY(-10px);box-shadow:0 24px 48px -8px rgba(0,0,0,.55),0 0 0 1px rgba(201,162,39,.35)}
.sub-card-icon{width:40px;height:40px;background:rgba(201,162,39,.12);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.sub-card:hover .sub-card-icon{transform:scale(1.12)}
.sub-card-icon svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.sub-card-logo{height:32px;margin-bottom:12px;object-fit:contain;filter:brightness(0) invert(1);opacity:.9}
.sub-card-logo-pill{background:#fff;border-radius:2px;padding:10px 14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;height:72px;width:100%;overflow:hidden}
.sub-card-logo-img{height:100%;width:auto;max-width:100%;object-fit:contain;display:block}
.sub-card-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:4px}
.sub-card-tagline{font-family:'Montserrat',sans-serif;font-size:9.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.sub-card-desc{font-size:.875rem;color:rgba(255,255,255,.55);line-height:1.75;margin-bottom:20px}
.sub-card-services{list-style:none;margin-bottom:24px}
.sub-card-services li{display:flex;align-items:center;gap:8px;font-family:'Montserrat',sans-serif;font-size:10.5px;color:rgba(255,255,255,.4);margin-bottom:6px}
.sub-card-services li::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0}
.sub-card-link{display:inline-flex;align-items:center;gap:6px;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);transition:color .25s,gap .25s}
.sub-card-link:hover{color:var(--gold-light);gap:10px}

/* CTA */
.cta-section{padding:88px 0;background:var(--cream-dark);text-align:center}
.cta-h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;color:var(--navy);margin-bottom:8px}
.cta-p{font-size:1rem;color:var(--text-mid);max-width:500px;margin:0 auto 36px;line-height:1.8}

/* FOOTER */
footer{background:var(--navy-dark);color:rgba(255,255,255,.55)}
.footer-gold-rule{height:3px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
.footer-grid{max-width:1200px;margin:0 auto;padding:64px 24px 48px;display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}
.footer-logo img{height:96px;width:auto;object-fit:contain;mix-blend-mode:lighten;margin-bottom:16px}
.footer-tagline{font-size:.875rem;line-height:1.75;max-width:260px}
.footer-col h4{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:rgba(255,255,255,.55);font-size:.875rem;transition:color .2s}
.footer-col ul li a:hover{color:var(--gold)}
.footer-contact-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:.875rem}
.footer-contact-row svg{width:14px;height:14px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:3px}
.footer-contact-row a{color:rgba(255,255,255,.55);transition:color .2s}
.footer-contact-row a:hover{color:var(--gold)}
.footer-contact-row span{color:rgba(255,255,255,.55)}
.footer-cta-link{display:inline-block;margin-top:16px;padding:8px 18px;border:1px solid var(--gold);color:var(--gold);font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;transition:background .25s}
.footer-cta-link:hover{background:rgba(201,162,39,.1)}
.footer-bottom{max-width:1200px;margin:0 auto;padding:18px 24px;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-bottom p,.footer-bottom a{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.5px;color:rgba(255,255,255,.3)}
.footer-bottom nav{display:flex;gap:20px}
.footer-bottom a:hover{color:rgba(255,255,255,.6)}

/* SCROLL TO TOP */
#scroll-top{position:fixed;bottom:28px;right:28px;z-index:200;width:46px;height:46px;border-radius:50%;background:var(--navy);border:1.5px solid var(--gold);color:var(--gold);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s,background .25s,transform .25s}
#scroll-top.visible{opacity:1;visibility:visible}
#scroll-top:hover{background:var(--gold);color:var(--navy);transform:translateY(-4px)}

/* PAGE HERO (About/Contact) */
.page-hero{position:relative;padding:100px 0 80px;background:var(--navy);overflow:hidden}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.12}
.page-hero-inner{position:relative;z-index:1}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700;color:#fff;margin-bottom:16px}
.page-hero h1 em{font-style:normal;color:var(--gold)}
.page-hero p{font-size:1.05rem;color:rgba(255,255,255,.7);max-width:560px;line-height:1.8}
.breadcrumb{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.breadcrumb a{color:rgba(255,255,255,.5);transition:color .2s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{margin:0 8px;color:rgba(255,255,255,.25)}

/* ABOUT PAGE */
.about-intro{padding:88px 0;background:var(--cream)}
.about-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:900px){.about-intro-grid{grid-template-columns:1fr;gap:40px}}
.about-h2{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3vw,2.5rem);font-weight:700;color:var(--navy);line-height:1.25;margin-bottom:8px}
.about-h2 em{font-style:normal;color:var(--gold)}
.about-p{font-size:1rem;color:var(--text-mid);line-height:1.85;margin-bottom:16px}
.about-img-wrap{position:relative}
.about-img-wrap::before{content:'';position:absolute;top:-14px;left:-14px;right:14px;bottom:14px;border:1px solid rgba(201,162,39,.3)}
.about-img-wrap img{position:relative;width:100%;height:360px;object-fit:cover}
@media(max-width:640px){.about-img-wrap img{height:240px}}
.pillars-section{padding:88px 0;background:var(--navy)}
.pillars-h2{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3vw,2.5rem);font-weight:700;color:#fff;margin-bottom:8px}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
@media(max-width:900px){.pillars-grid{grid-template-columns:1fr}}
@media(min-width:600px) and (max-width:900px){.pillars-grid{grid-template-columns:1fr 1fr}}
.pillar-card{background:rgba(255,255,255,.04);border:1px solid rgba(201,162,39,.15);padding:32px;transition:border-color .3s,background .3s}
.pillar-card:hover{border-color:rgba(201,162,39,.5);background:rgba(255,255,255,.07)}
.pillar-num{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:700;color:rgba(201,162,39,.2);line-height:1;margin-bottom:16px}
.pillar-title{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.pillar-desc{font-size:.9rem;color:rgba(255,255,255,.55);line-height:1.75}
.subs-detail{padding:88px 0;background:var(--cream-dark)}
.subs-detail-h2{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3vw,2.5rem);font-weight:700;color:var(--navy);margin-bottom:8px}
.sub-detail-item{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:56px 0;border-bottom:1px solid rgba(0,0,0,.08)}
.sub-detail-item:last-child{border-bottom:none}
.sub-detail-item.reverse{direction:rtl}
.sub-detail-item.reverse > *{direction:ltr}
@media(max-width:900px){.sub-detail-item,.sub-detail-item.reverse{grid-template-columns:1fr;direction:ltr;gap:32px}}
.sub-detail-logo{height:44px;width:auto;object-fit:contain;margin-bottom:16px}
.sub-detail-name{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--navy);margin-bottom:6px}
.sub-detail-tagline{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.sub-detail-p{font-size:.95rem;color:var(--text-mid);line-height:1.85;margin-bottom:16px}
.sub-detail-services{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.sub-detail-tag{font-family:'Montserrat',sans-serif;font-size:9.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:5px 12px;border:1px solid rgba(201,162,39,.4);color:var(--gold)}
.sub-detail-placeholder{width:100%;height:300px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);display:flex;align-items:center;justify-content:center}
.sub-detail-placeholder svg{width:64px;height:64px;stroke:rgba(201,162,39,.3);fill:none;stroke-width:1}
.about-cta{padding:88px 0;background:var(--navy);text-align:center}
.about-cta h2{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3vw,2.5rem);font-weight:700;color:#fff;margin-bottom:8px}
.about-cta p{font-size:1rem;color:rgba(255,255,255,.65);max-width:480px;margin:0 auto 32px;line-height:1.8}

/* CONTACT PAGE */
.contact-section{padding:88px 0;background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:48px}}
.contact-info-h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.3rem);font-weight:700;color:var(--navy);margin-bottom:8px}
.contact-info-h2 em{font-style:normal;color:var(--gold)}
.contact-info-p{font-size:.95rem;color:var(--text-mid);line-height:1.85;margin-bottom:32px}
.contact-detail{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}
.contact-detail-icon{width:44px;height:44px;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-detail-icon svg{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.contact-detail-label{font-family:'Montserrat',sans-serif;font-size:9.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.contact-detail-value{font-size:.9rem;color:var(--text-mid);line-height:1.6}
.contact-detail-value a{color:var(--text-mid);transition:color .2s}
.contact-detail-value a:hover{color:var(--navy)}
.contact-form-wrap{background:#fff;padding:40px;box-shadow:0 4px 32px rgba(0,0,0,.07)}
.contact-form-title{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--navy);margin-bottom:4px}
.contact-form-subtitle{font-size:.875rem;color:var(--text-mid);margin-bottom:28px}
.form-group{margin-bottom:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.form-group label{display:block;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--navy);margin-bottom:8px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:1px solid #d8d4cc;background:#faf9f7;font-family:'Source Serif 4',serif;font-size:.9rem;color:var(--text-dark);transition:border-color .25s,box-shadow .25s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,.12)}
.form-group textarea{resize:vertical;min-height:130px}
.form-submit{width:100%;padding:14px;background:var(--navy);color:#fff;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;transition:background .25s}
.form-submit:hover{background:var(--navy-mid)}
.form-submit:disabled{opacity:.6;cursor:not-allowed}
.form-success{display:none;text-align:center;padding:40px 20px}
.form-success.show{display:block}
.form-success-icon{width:56px;height:56px;background:rgba(201,162,39,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.form-success-icon svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.form-success h3{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.form-success p{font-size:.9rem;color:var(--text-mid)}
.map-section{padding:0 0 88px;background:var(--cream)}
.map-wrap{position:relative;padding-bottom:45%;height:0;overflow:hidden}
.map-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}

/* COOKIE BANNER */
#cookie-banner{display:none;position:fixed;bottom:0;left:0;right:0;z-index:10000;transform:translateY(100%);opacity:0;transition:transform .45s cubic-bezier(.34,1.56,.64,1),opacity .45s ease}
#cookie-banner.cookie-visible{transform:translateY(0);opacity:1}
.cookie-gold-rule{height:3px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
.cookie-inner{background:#071428;border-top:1px solid rgba(201,162,39,.2);padding:16px 24px}
.cookie-body{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
@media(min-width:768px){.cookie-body{flex-direction:row;align-items:center;gap:24px}}
.cookie-text-wrap{display:flex;align-items:flex-start;gap:12px;flex:1}
.cookie-icon{flex-shrink:0;margin-top:2px;color:var(--gold)}
.cookie-title{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;letter-spacing:.05em;color:#fff;margin-bottom:4px}
.cookie-desc{font-family:'Source Serif 4',serif;font-size:11.5px;color:rgba(200,210,220,.75);line-height:1.6}
.cookie-learn-btn{background:none;border:none;cursor:pointer;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:.05em;color:var(--gold);text-decoration:underline;padding:0;margin-left:4px}
.cookie-learn-btn:hover{color:#e0b840}
.cookie-detail{display:none;font-family:'Source Serif 4',serif;font-size:11px;color:rgba(180,190,200,.65);line-height:1.65;margin-top:8px}
.cookie-detail a{color:var(--gold);text-decoration:underline}
.cookie-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}
@media(min-width:480px){.cookie-actions{flex-direction:row}}
.cookie-btn{padding:9px 18px;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;transition:background .2s,color .2s;white-space:nowrap}
.cookie-btn-accept{background:var(--gold);color:#071428}
.cookie-btn-accept:hover{background:var(--gold-light)}
.cookie-btn-reject,.cookie-btn-manage{background:transparent;color:rgba(255,255,255,.7);border:1px solid rgba(201,162,39,.35)}
.cookie-btn-reject:hover,.cookie-btn-manage:hover{background:rgba(255,255,255,.08);color:#fff}

/* COOKIE MODAL */
#cookie-modal{display:none;position:fixed;inset:0;z-index:10001;background:rgba(7,20,40,.88);align-items:center;justify-content:center;padding:16px}
.cookie-modal-box{background:oklch(0.18 0.055 248);border:1px solid rgba(201,162,39,.25);width:100%;max-width:520px;border-radius:2px;overflow:hidden}
.cookie-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(201,162,39,.15)}
.cookie-modal-title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:10px}
.cookie-modal-close{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.5);font-size:18px;line-height:1;padding:4px;transition:color .2s}
.cookie-modal-close:hover{color:#fff}
.cookie-modal-body{padding:20px 24px;max-height:65vh;overflow-y:auto}
.cookie-modal-intro{font-family:'Source Serif 4',serif;font-size:.875rem;color:rgba(180,195,210,.75);line-height:1.75;margin-bottom:20px}
.cookie-cat{background:oklch(0.14 0.05 248);border:1px solid rgba(201,162,39,.1);padding:16px;margin-bottom:12px;border-radius:2px}
.cookie-cat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.cookie-cat-name{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;color:#fff}
.cookie-cat-desc{font-size:.8rem;color:rgba(160,175,190,.65);line-height:1.6}
.cookie-always-badge{font-family:'Montserrat',sans-serif;font-size:9px;font-weight:700;letter-spacing:.5px;padding:3px 8px;background:rgba(201,162,39,.15);color:var(--gold);border-radius:2px}
.toggle-wrap{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.cookie-toggle{opacity:0;width:0;height:0;position:absolute}
.toggle-track{position:absolute;inset:0;border-radius:12px;background:rgba(100,120,140,.4);transition:background .2s;cursor:pointer}
.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.3);transition:transform .2s;pointer-events:none}
.cookie-toggle:checked + .toggle-track{background:var(--gold)}
.cookie-toggle:checked ~ .toggle-knob,.cookie-toggle:checked + .toggle-track + .toggle-knob{transform:translateX(20px)}
.cookie-modal-links{font-size:.75rem;color:rgba(120,135,150,.6);margin-top:16px}
.cookie-modal-links a{color:var(--gold);text-decoration:underline}
.cookie-modal-footer{display:flex;flex-direction:column;gap:10px;padding:16px 24px;border-top:1px solid rgba(201,162,39,.15)}
@media(min-width:480px){.cookie-modal-footer{flex-direction:row}}
.cookie-modal-footer .cookie-btn{flex:1;padding:11px 16px;font-size:10px}

/* ═══════════════════════════════════════════════════════════════
   ABOUT PAGE (NEW) — matches React About.tsx layout exactly
   ═══════════════════════════════════════════════════════════════ */

/* Gold rule helpers */
.gold-rule-sm{width:48px;height:1px;background:oklch(0.72 0.12 80);margin-bottom:24px}
.gold-rule-center{width:64px;height:1px;background:oklch(0.72 0.12 80);margin:0 auto 48px}

/* PAGE HEADER — navy bg, background image at 12% opacity, centered text */
.about-page-header{position:relative;background-color:oklch(0.18 0.055 248);padding:96px 0 80px;overflow:hidden}
.about-page-header-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0.12}
.about-page-header-inner{position:relative;z-index:1}
.about-page-h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:700;color:#fff;line-height:1.15;margin-bottom:20px}

/* COMPANY OVERVIEW — cream bg, 2-col grid (image left, text right) */
.about-overview-section{background-color:oklch(0.97 0.008 80);padding:80px 0}
.about-overview-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.about-overview-grid{grid-template-columns:1fr 1fr}}
.about-overview-img-col{order:2}
@media(min-width:1024px){.about-overview-img-col{order:1}}
.about-overview-text-col{order:1}
@media(min-width:1024px){.about-overview-text-col{order:2}}
.about-overview-img-wrap{position:relative}
.about-overview-img-wrap::before{content:'';position:absolute;top:-12px;left:-12px;width:100%;height:100%;border:1px solid oklch(0.72 0.12 80 / 0.3);pointer-events:none}
.about-overview-img{position:relative;width:100%;height:320px;object-fit:cover;display:block}
@media(min-width:768px){.about-overview-img{height:400px}}
.about-overview-h2{font-family:'Playfair Display',serif;font-size:clamp(1.75rem,3.5vw,2.75rem);font-weight:700;color:oklch(0.18 0.055 248);line-height:1.2;margin-bottom:20px}
.about-overview-p{font-family:'Source Serif 4',serif;font-size:1rem;line-height:1.8;color:oklch(0.30 0.03 248);margin-bottom:16px}
.about-overview-p:last-child{margin-bottom:0}

/* CORE VALUES — lighter cream bg, 4-card grid */
.about-values-section{background-color:oklch(0.95 0.01 80);padding:80px 0}
.about-values-header{margin-bottom:40px}
.about-values-h2{font-family:'Playfair Display',serif;font-size:clamp(1.75rem,3.5vw,2.75rem);font-weight:700;color:oklch(0.18 0.055 248);line-height:1.2;margin-bottom:0}
.about-values-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:640px){.about-values-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.about-values-grid{grid-template-columns:repeat(4,1fr)}}
.about-value-card{background:#fff;border:1px solid oklch(0.72 0.12 80 / 0.2);padding:28px 24px;border-radius:2px;transition:box-shadow .3s ease,transform .3s ease}
.about-value-card:hover{box-shadow:0 8px 24px -4px rgba(0,0,0,.12);transform:translateY(-4px)}
.about-value-title{font-family:'Montserrat',sans-serif;font-size:.875rem;font-weight:700;letter-spacing:.04em;color:oklch(0.18 0.055 248);margin-bottom:8px}
.about-value-desc{font-family:'Source Serif 4',serif;font-size:.875rem;line-height:1.7;color:oklch(0.35 0.03 248);margin:0}

/* CORE SUBSIDIARIES — dark navy bg, stacked full-width cards */
.about-subs-section{background-color:oklch(0.18 0.055 248);padding:80px 0}
.about-subs-header{text-align:center;margin-bottom:0}
.about-subs-h2{font-family:'Playfair Display',serif;font-size:clamp(1.75rem,3.5vw,2.75rem);font-weight:700;color:#fff;margin-bottom:20px}
.about-subs-list{display:flex;flex-direction:column;gap:24px}
.about-sub-card{background:oklch(0.14 0.05 248);border:1px solid rgba(201,162,39,.15);padding:32px;border-radius:2px;transition:border-color .3s ease}
.about-sub-card:hover{border-color:rgba(201,162,39,.4)}
.about-sub-card-grid{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:768px){.about-sub-card-grid{grid-template-columns:220px 1fr 200px}}
/* Left: identity */
.about-sub-identity{display:flex;flex-direction:column;gap:12px}
.about-sub-icon-box{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(201,162,39,.12);border-radius:2px;flex-shrink:0}
.about-sub-logo-wrap{display:flex;align-items:center}
.about-sub-logo-img{max-width:160px;max-height:48px;width:auto;height:auto;object-fit:contain;display:block}
.about-sub-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:#fff;margin:0}
.about-sub-tagline{font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:oklch(0.72 0.12 80);line-height:1.4;margin:0}
.about-sub-focus{font-family:'Source Serif 4',serif;font-size:.8rem;color:rgba(180,195,210,.6);line-height:1.6;margin:0}
/* Middle: description */
.about-sub-desc-col{display:flex;align-items:flex-start}
.about-sub-desc{font-family:'Source Serif 4',serif;font-size:.9375rem;line-height:1.8;color:rgba(200,215,230,.8);margin:0}
/* Right: services + CTA */
.about-sub-services-col{display:flex;flex-direction:column;gap:16px}
.about-sub-services-label{font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:oklch(0.72 0.12 80);margin:0 0 4px}
.about-sub-services-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;flex:1}
.about-sub-services-list li{display:flex;align-items:flex-start;gap:8px;font-family:'Source Serif 4',serif;font-size:.8125rem;color:rgba(180,195,210,.75);line-height:1.5}
.about-sub-bullet{display:inline-block;width:4px;height:4px;border-radius:50%;background:oklch(0.72 0.12 80);flex-shrink:0;margin-top:6px}
.about-sub-visit-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:oklch(0.72 0.12 80);border:1px solid oklch(0.72 0.12 80 / 0.4);background:transparent;text-decoration:none;transition:background .25s,border-color .25s,color .25s;align-self:flex-start}
.about-sub-visit-btn:hover{background:oklch(0.72 0.12 80 / 0.12);border-color:oklch(0.72 0.12 80);color:#fff}

/* Footer subsidiary links (new style) */
.footer-sub-link{display:flex;align-items:flex-start;gap:8px;color:rgba(255,255,255,.55);font-size:.875rem;transition:color .2s;text-decoration:none}
.footer-sub-link:hover{color:var(--gold)}
.footer-sub-name{display:block;font-size:.875rem;line-height:1.4}
.footer-sub-desc{display:block;font-family:'Montserrat',sans-serif;font-size:.7rem;letter-spacing:.04em;color:rgba(255,255,255,.3);margin-top:2px}
