*{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#7D9A9E;
  --sage:#B9C0CC;
  --ivory:#FFFFF5;
  --lav:#E8E9ED;
  --ink:#1d1d1b;
  --muted:#676a67;
}
html{scroll-behavior:smooth}
body{font-family:Archivo,Arial,sans-serif;background:var(--ivory);color:var(--ink);overflow-x:hidden}
body:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 15% 20%, rgba(125,154,158,.16), transparent 30%),radial-gradient(circle at 85% 35%, rgba(185,192,204,.24), transparent 28%),radial-gradient(circle at 30% 90%, rgba(232,233,237,.6), transparent 30%);pointer-events:none;z-index:-1}
.cursor-dot{position:fixed;width:18px;height:18px;border-radius:50%;background:var(--blue);opacity:.45;z-index:50;pointer-events:none;transform:translate(-50%,-50%);transition:width .2s,height .2s}
.site-header{position:fixed;top:0;left:0;width:100%;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:20px 5vw;background:rgba(255,255,245,.78);backdrop-filter:blur(14px);border-bottom:1px solid rgba(29,29,27,.08)}
.logo img{width:92px;display:block}
.site-header nav{display:flex;gap:38px}
.line-link{color:var(--ink);text-decoration:none;font-size:13px;text-transform:uppercase;letter-spacing:.1em;font-weight:800;position:relative;display:inline-block}
.line-link:after{content:"";position:absolute;left:0;bottom:-7px;width:100%;height:2px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .35s ease}
.line-link:hover:after{transform:scaleX(1);transform-origin:left}
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 5vw 70px;position:relative}
.hero-map-wrap{width:min(650px,88vw);position:relative;animation:floatMap 4.2s ease-in-out infinite alternate}
.hero-map-wrap:after{content:"";position:absolute;left:18%;right:18%;bottom:3%;height:28px;background:rgba(29,29,27,.16);filter:blur(18px);border-radius:50%;z-index:-1;animation:shadowPulse 4.2s ease-in-out infinite alternate}
.drc-map{width:100%;display:block;mix-blend-mode:multiply}
@keyframes floatMap{to{transform:translateY(-18px) scale(1.015)}}
@keyframes shadowPulse{to{opacity:.55;transform:scale(.86)}}
.hero-title{font-family:"Instrument Serif",serif;font-size:clamp(42px,6vw,92px);font-weight:400;line-height:.95;letter-spacing:-.04em;max-width:980px;margin-top:18px}
.scroll-hint{margin-top:34px;color:var(--blue)}
.brands{padding:80px 5vw 40px}
.brand-section{min-height:88vh;display:grid;grid-template-columns:1fr 1fr;gap:5vw;align-items:center;padding:80px 0;border-top:1px solid rgba(29,29,27,.12)}
.brand-section:nth-child(even) .brand-visual{order:2}
.brand-visual{position:relative;min-height:520px;border-radius:42px;background:linear-gradient(135deg,var(--lav),var(--ivory));overflow:hidden}
.brand-visual:before{content:"";position:absolute;inset:28px;border:1px solid rgba(29,29,27,.12);border-radius:30px;z-index:2;pointer-events:none}
.brand-image{width:100%;height:100%;min-height:520px;object-fit:cover;display:block;opacity:.78;filter:saturate(.75) contrast(.95)}
.floating-logo{position:absolute;width:min(250px,48%);height:auto;object-fit:contain;right:8%;bottom:9%;animation:bounceLogo 3s ease-in-out infinite alternate;filter:drop-shadow(0 18px 28px rgba(29,29,27,.18))}
@keyframes bounceLogo{to{transform:translateY(-16px) rotate(-2deg)}}
.brand-copy span,.section-label{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--blue);font-weight:900}
.brand-copy h2,.about h2,.contact h2{font-size:clamp(48px,7vw,104px);line-height:.82;letter-spacing:-.065em;margin:20px 0;font-weight:900}
.brand-copy .tagline{font-size:14px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:900;margin-bottom:20px}
.brand-copy p{font-size:18px;line-height:1.7;color:#3b3d3a;max-width:620px;margin-bottom:30px}
.brand-link{color:var(--blue)}
.about,.contact{margin:0 5vw;padding:110px 0;border-top:1px solid rgba(29,29,27,.14);display:grid;grid-template-columns:.9fr 1.1fr;gap:6vw;align-items:start}
.about p,.contact p{font-size:20px;line-height:1.7;color:#3b3d3a}
.contact-list{display:grid;gap:22px;align-content:start}
.contact-list a{font-size:18px;text-transform:none;letter-spacing:.02em}
footer{margin:0 5vw;padding:38px 0;border-top:1px solid rgba(29,29,27,.14);display:flex;align-items:center;justify-content:space-between;color:var(--muted)}
footer img{width:76px}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .75s ease,transform .75s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:820px){
  .cursor-dot{display:none}
  .site-header{padding:16px 5vw}
  .logo img{width:76px}
  .site-header nav{gap:18px}
  .site-header nav a{font-size:10px;letter-spacing:.04em}
  .hero{padding-top:105px;justify-content:center}
  .hero-map-wrap{width:min(430px,96vw)}
  .hero-title{font-size:clamp(40px,12vw,64px);margin-top:10px}
  .brand-section,.brand-section:nth-child(even){display:flex;flex-direction:column;gap:28px;min-height:auto;padding:70px 0}
  .brand-section:nth-child(even) .brand-visual{order:0}
  .brand-visual{width:100%;min-height:330px;border-radius:30px}
  .brand-image{min-height:330px}
  .floating-logo{width:min(180px,52%);right:6%;bottom:8%}
  .brand-copy h2,.about h2,.contact h2{font-size:clamp(44px,14vw,68px)}
  .brand-copy p{font-size:16px}
  .about,.contact{display:block;padding:82px 0}
  .about p,.contact p{font-size:17px;margin-top:22px}
  .contact-list{margin-top:34px}
  footer{flex-direction:column;gap:16px;text-align:center}
}
@media(max-width:480px){
  .site-header nav{display:none}
  .hero-map-wrap{width:108vw}
  .drc-map{transform:scale(1.08)}
  .hero-title{font-size:47px}
  .scroll-hint{margin-top:22px}
}
